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

{% block title %}Grade {{ alias }} - {{ 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">
                <a href="{% url 'questions:grading_overview' question.pk %}{% if request.GET.inspect_session %}?inspect_session={{ request.GET.inspect_session }}{% endif %}" class="text-decoration-none">
                    Grade Model Answers
                </a>
            </li>
            <li class="breadcrumb-item active">{{ alias }}</li>
        </ol>
    </nav>
</div>
{% endblock %}

{% block content %}
<div class="container-fluid px-3">
    <!-- Tab Navigation -->
    <div class="card mb-3">
        <div class="card-body py-2">
            <div class="d-flex align-items-center">
                <ul class="nav nav-pills nav-fill flex-grow-1">
                    {% for tab in tabs %}
                    <li class="nav-item">
                        <a class="nav-link {% if tab.is_current %}active{% endif %} 
                           {% if tab.status == 'completed' %}text-success{% elif tab.status == 'in_progress' %}text-warning{% elif tab.status == 'given_up' %}text-danger{% endif %}"
                           href="{{ tab.url }}">
                            {{ tab.alias }}
                            {% if tab.tier_group == 1 %}
                                <span class="badge bg-warning text-dark ms-1">T1</span>
                            {% elif tab.tier_group == 3 %}
                                <span class="badge bg-info text-dark ms-1">T4+</span>
                            {% endif %}
                            {% if tab.status == 'completed' %}
                                <i class="bi bi-check-circle-fill ms-1"></i>
                            {% elif tab.status == 'in_progress' %}
                                <i class="bi bi-hourglass-split ms-1"></i>
                            {% elif tab.status == 'given_up' %}
                                <i class="bi bi-x-circle-fill ms-1"></i>
                            {% endif %}
                        </a>
                    </li>
                    {% endfor %}
                </ul>
                <a href="{% url 'questions:grading_focus' question.pk alias %}{% if request.GET.inspect_session %}?inspect_session={{ request.GET.inspect_session }}{% endif %}" 
                   class="btn btn-outline-primary btn-sm ms-3" 
                   data-bs-toggle="tooltip" title="Enter focus mode for distraction-free grading">
                    <i class="bi bi-arrows-fullscreen me-1"></i>
                    Focus Mode
                </a>
            </div>
        </div>
    </div>

    <!-- Grading Notes Section (Collapsible) -->
    <div class="card mb-3">
        <div class="card-header py-2 bg-light">
            <div class="d-flex justify-content-between align-items-center">
                <h6 class="mb-0">
                    <i class="bi bi-pencil-square me-2"></i>
                    Grading Notes
                    <i class="bi bi-info-circle text-muted ms-2" data-bs-toggle="tooltip" 
                       title="Record your grading decisions and patterns across all answers. For example, note which false arguments count as Calculation Mistakes vs. Incorrect Logic. These notes persist across all answers for this question."></i>
                </h6>
                <button class="btn btn-sm btn-outline-secondary" type="button" data-bs-toggle="collapse" 
                        data-bs-target="#gradingNotesCollapse" aria-expanded="false" aria-controls="gradingNotesCollapse">
                    <i class="bi bi-chevron-down" id="gradingNotesToggleIcon"></i>
                </button>
            </div>
        </div>
        <div class="collapse" id="gradingNotesCollapse">
            <div class="card-body py-2">
                <textarea class="form-control" id="grading-notes" rows="3" 
                          placeholder="Enter your grading notes here... (e.g., 'Counting matrix calculation errors as Calculation Mistakes, theoretical errors as Incorrect Logic')"
                          {% if session.is_finalized %}disabled{% endif %}>{{ session.grader_notes|default:"" }}</textarea>
                <small class="text-muted">These notes are shared across all answers for this question and auto-save as you type.</small>
            </div>
        </div>
    </div>

    <!-- Main Content Area -->
    <div class="row">
        <!-- Left Column: Question and Model Response -->
        <div class="col-lg-9">
            <div class="row h-100">
                <!-- Question Display -->
                <div class="col-lg-6 mb-3">
                    <div class="card" style="height: calc(100vh - 2rem); display: flex; flex-direction: column;">
                        <div class="card-header bg-primary text-white flex-shrink-0">
                            <h5 class="mb-0">
                                <i class="bi bi-question-circle me-2"></i>
                                Question & Solution
                            </h5>
                        </div>
                        <div class="card-body overflow-auto" style="flex: 1;">
                            {% include 'includes/question_display.html' with question=question show_solution=True show_metadata=False %}
                        </div>
                    </div>
                </div>

                <!-- AI Model Response -->
                <div class="col-lg-6 mb-3" id="answer-column">
                    <div class="card" style="height: calc(100vh - 2rem); display: flex; flex-direction: column;">
                        <div class="card-header bg-info text-white flex-shrink-0">
                            <h5 class="mb-0">
                                <i class="bi bi-robot me-2"></i>
                                Model {{ alias|slice:"7:" }} Response
                            </h5>
                        </div>
                        <div class="card-body overflow-auto" style="flex: 1;">
                            {% include 'includes/model_answer_display.html' with answer_text=model_answer.answer show_toggle=True %}
                        </div>
                    </div>
                </div>
            </div>
        </div>

        <!-- Right Column: Grading Panel -->
        <div class="col-lg-3">
            <div class="card" style="position: sticky; top: 1rem; height: calc(100vh - 2rem); display: flex; flex-direction: column;">
                <div class="card-header bg-warning flex-shrink-0">
                    <h5 class="mb-0 text-dark">
                        <i class="bi bi-clipboard-check me-2"></i>
                        Grading Panel
                    </h5>
                </div>
                <div class="card-body" style="overflow-y: auto; flex: 1;">
                    <!-- Auto-save indicator -->
                    <div id="save-indicator" class="alert alert-info py-1 px-2 text-center small">
                        <i class="bi bi-cloud-check me-1"></i>
                        Auto-save enabled
                    </div>

                    {% if grading.grading_status == 'completed' and not session.is_finalized %}
                    <!-- Completed grading notice -->
                    <div class="alert alert-warning py-2 px-2 text-center">
                        <i class="bi bi-lock me-1"></i>
                        <strong>Grading Completed</strong><br>
                        <small>Click "Mark as Incomplete" below to edit</small>
                    </div>
                    {% endif %}

                    <form id="grading-form">
                        {% csrf_token %}
                        
                        <!-- Part A: AI Mistake Indicators -->
                        <h6 class="mt-3 mb-2">
                            AI Mistake Indicators
                        </h6>
                        
                        <div class="mb-2">
                            <label class="form-label small mb-1">
                                1. Incorrect Logic or Reasoning
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Flawed logical steps or invalid reasoning"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_incorrect_logic" 
                                       id="error_incorrect_logic_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_incorrect_logic_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary" for="error_incorrect_logic_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-2">
                            <label class="form-label small mb-1">
                                2. Hallucinated Results or Literature
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="References to non-existent theorems, papers, or results"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_hallucinated" 
                                       id="error_hallucinated_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_hallucinated_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary" for="error_hallucinated_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-2">
                            <label class="form-label small mb-1">
                                3. Calculation Mistakes
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Arithmetic or algebraic errors"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_calculation" 
                                       id="error_calculation_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_calculation_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary" for="error_calculation_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-2">
                            <label class="form-label small mb-1">
                                4. Conceptual Misunderstanding
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Fundamental misunderstanding of mathematical concepts"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="error_conceptual" 
                                       id="error_conceptual_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.error_conceptual_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary" for="error_conceptual_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <hr class="my-3">

                        <!-- Part B: AI Achievement Indicators -->
                        <h6 class="mb-2">
                            AI Achievement Indicators
                        </h6>

                        <div class="mb-2">
                            <label class="form-label small mb-1">
                                5. Problem Understanding
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Correctly identifies what needs to be proven or calculated"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_understanding" 
                                       id="achievement_understanding_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_understanding_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary" for="achievement_understanding_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-2">
                            <div class="d-flex justify-content-between align-items-center mb-1">
                                <label class="form-label small mb-0">
                                    6. Correct End Result
                                    <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                       title="Arrives at the correct final answer. Use N/A toggle if the problem doesn't have a definitive answer (e.g., open-ended proofs or construction problems) or if the correct answer is not known"></i>
                                </label>
                                <div class="form-check form-switch">
                                    <input class="form-check-input" type="checkbox" id="na_toggle" 
                                           data-bs-toggle="tooltip" 
                                           title="Toggle if this question has no definitive correct answer or if the answer is not known"
                                           {% if grading.achievement_correct_result_id == 4 %}checked{% endif %}
                                           {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                    <label class="form-check-label small" for="na_toggle">N/A</label>
                                </div>
                            </div>
                            <div class="btn-group btn-group-sm w-100" role="group" id="correct_result_buttons">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_correct_result" 
                                       id="achievement_correct_result_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_correct_result_id == state.id %}checked{% endif %}
                                       {% if grading.achievement_correct_result_id == 4 or grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary {% if grading.achievement_correct_result_id == 4 %}disabled{% endif %}" 
                                       for="achievement_correct_result_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-2">
                            <label class="form-label small mb-1">
                                7. Insight and Creativity
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Shows creative problem-solving or novel approaches"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_insight" 
                                       id="achievement_insight_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_insight_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary" for="achievement_insight_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <div class="mb-2">
                            <label class="form-label small mb-1">
                                8. Practical Usefulness
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Solution would be helpful to someone learning this topic"></i>
                            </label>
                            <div class="btn-group btn-group-sm w-100" role="group">
                                {% for state in grading_states %}
                                {% if state.state_type == 'binary' %}
                                <input type="radio" class="btn-check" name="achievement_usefulness" 
                                       id="achievement_usefulness_{{ state.id }}" value="{{ state.id }}"
                                       {% if grading.achievement_usefulness_id == state.id %}checked{% endif %}
                                       {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                                <label class="btn btn-outline-secondary" for="achievement_usefulness_{{ state.id }}" style="flex: 1;">
                                    {{ state.state_label }}
                                </label>
                                {% endif %}
                                {% endfor %}
                            </div>
                        </div>

                        <hr class="my-3">

                        <!-- Part C: Overall Progress -->
                        <h6 class="mb-2">
                            <i class="bi bi-speedometer2 me-1"></i>
                            Overall Progress Grade
                            <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                               title="Rate the overall progress toward solving the problem. This is the primary score used for ranking. Hover over each option below for detailed criteria."></i>
                        </h6>
                        
                        <div class="btn-group btn-group-sm w-100 mb-3" role="group">
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_0" value="0"
                                   {% if grading.progress_grade == 0 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary" for="progress_0"
                                   data-bs-toggle="tooltip" 
                                   title="No Progress: The model shows no understanding of the problem or makes no meaningful attempt at a solution"
                                   style="flex: 1;">
                                0<br><small>None</small>
                            </label>
                            
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_1" value="1"
                                   {% if grading.progress_grade == 1 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary" for="progress_1"
                                   data-bs-toggle="tooltip" 
                                   title="Minor Progress: The model understands the problem and makes some correct initial steps, but doesn't get far toward a solution"
                                   style="flex: 1;">
                                1<br><small>Minor</small>
                            </label>
                            
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_2" value="2"
                                   {% if grading.progress_grade == 2 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary" for="progress_2"
                                   data-bs-toggle="tooltip" 
                                   title="Major Progress: The model makes substantial progress with mostly correct reasoning, but has some gaps or errors preventing a complete solution"
                                   style="flex: 1;">
                                2<br><small>Major</small>
                            </label>
                            
                            <input type="radio" class="btn-check" name="progress_grade" 
                                   id="progress_3" value="3"
                                   {% if grading.progress_grade == 3 %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="btn btn-outline-secondary" for="progress_3"
                                   data-bs-toggle="tooltip" 
                                   title="Complete Solution: The model provides a correct and complete solution to the problem with valid reasoning throughout"
                                   style="flex: 1;">
                                3<br><small>Complete</small>
                            </label>
                        </div>

                        <!-- Comments -->
                        <div class="mb-3">
                            <label for="comments" class="form-label small">
                                Comments (Optional)
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Add any additional observations, notes about edge cases, or explanations for your grading decisions"></i>
                            </label>
                            <textarea class="form-control form-control-sm" id="comments" name="comments" 
                                      rows="3" {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>{{ grading.comments|default:"" }}</textarea>
                        </div>

                        <!-- Flag for Organizers -->
                        <div class="form-check mb-3">
                            <input class="form-check-input" type="checkbox" id="flag_for_organizers" 
                                   name="flag_for_organizers" {% if grading.flag_for_organizers %}checked{% endif %}
                                   {% if grading.grading_status == 'completed' or session.is_finalized %}disabled{% endif %}>
                            <label class="form-check-label small" for="flag_for_organizers">
                                <i class="bi bi-flag-fill text-danger me-1"></i>
                                Flag for organizers
                                <i class="bi bi-info-circle text-muted" data-bs-toggle="tooltip" 
                                   title="Check this if there are serious issues that require organizer attention (e.g., completely nonsensical response or technical problems)"></i>
                            </label>
                        </div>

                        <!-- Action Buttons -->
                        <div class="d-grid gap-2">
                            {% if grading.grading_status == 'completed' %}
                                <button type="button" class="btn btn-warning" id="mark-incomplete-btn"
                                        {% if session.is_finalized %}disabled{% endif %}
                                        data-bs-toggle="tooltip" 
                                        title="Mark this answer's grading as incomplete to continue editing.">
                                    <i class="bi bi-arrow-counterclockwise me-1"></i>
                                    Mark as Incomplete
                                </button>
                                <button type="button" class="btn btn-danger btn-sm" id="give-up-btn"
                                        data-bs-toggle="tooltip" 
                                        title="Skip grading this specific answer if it's too difficult to evaluate."
                                        disabled>
                                    <i class="bi bi-x-circle me-1"></i>
                                    Give Up on Grading This Answer
                                </button>
                            {% else %}
                                <button type="button" class="btn btn-success" id="mark-complete-btn"
                                        data-bs-toggle="tooltip" 
                                        title="Mark this answer's grading as complete. You can still edit it later if needed.">
                                    <i class="bi bi-check-circle me-1"></i>
                                    Mark as Complete
                                </button>
                                <button type="button" class="btn btn-danger btn-sm" id="give-up-btn"
                                        data-bs-toggle="tooltip" 
                                        title="Skip grading this specific answer if it's too difficult to evaluate. You can continue with other answers."
                                        {% if grading.grading_status == 'given_up' %}disabled{% endif %}>
                                    <i class="bi bi-x-circle me-1"></i>
                                    Give Up on Grading This Answer
                                </button>
                            {% endif %}
                        </div>
                    </form>
                </div>
            </div>
        </div>
    </div>
</div>
{% endblock %}

{% block extra_css %}
<style>
    /* Custom styling for active tabs to show status colors */
    .nav-pills .nav-link.active {
        background-color: transparent !important;
        color: inherit !important;
        border: 2px solid #0d6efd !important;
        font-weight: 600;
    }
    
    .nav-pills .nav-link {
        border: 2px solid transparent;
        transition: all 0.2s;
    }
    
    .nav-pills .nav-link:hover:not(.active) {
        background-color: #f8f9fa;
    }
    
    /* Ensure status colors are visible */
    .nav-pills .nav-link.text-success {
        color: #198754 !important;
    }
    
    .nav-pills .nav-link.text-warning {
        color: #ffc107 !important;
    }
    
    .nav-pills .nav-link.text-danger {
        color: #dc3545 !important;
    }
    
    /* Make tier badges stand out */
    .nav-pills .nav-link .badge {
        opacity: 0.9;
    }
</style>
{% endblock %}

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

// Check if grading is disabled (completed or finalized)
const isGradingDisabled = {% if grading.grading_status == 'completed' or session.is_finalized %}true{% else %}false{% endif %};
const isSessionFinalized = {% if session.is_finalized %}true{% else %}false{% endif %};

// Add visual cues and tooltips when grading is completed but not finalized
if (isGradingDisabled && !isSessionFinalized) {
    // Add cursor style to all disabled button labels
    document.querySelectorAll('#grading-form label.btn').forEach(label => {
        const forId = label.getAttribute('for');
        if (forId) {
            const input = document.getElementById(forId);
            if (input && input.disabled) {
                label.style.cursor = 'not-allowed';
                label.style.opacity = '0.8';
            }
        }
    });
    
    // Add tooltip to comments textarea (where tooltips work reliably)
    const commentsField = document.getElementById('comments');
    if (commentsField && commentsField.disabled) {
        commentsField.setAttribute('data-bs-toggle', 'tooltip');
        commentsField.setAttribute('data-bs-placement', 'top');
        commentsField.setAttribute('title', 'Click "Mark as Incomplete" below to edit your grading');
        commentsField.style.cursor = 'not-allowed';
        new bootstrap.Tooltip(commentsField);
    }
    
    // Add cursor style to N/A toggle area
    const naToggle = document.getElementById('na_toggle');
    if (naToggle && naToggle.disabled) {
        naToggle.style.cursor = 'not-allowed';
    }
    
    const naToggleLabel = document.querySelector('label[for="na_toggle"]');
    if (naToggleLabel) {
        naToggleLabel.style.cursor = 'not-allowed';
    }
    
    // Also add a visual hint to the Mark as Incomplete button
    const markIncompleteBtn = document.getElementById('mark-incomplete-btn');
    if (markIncompleteBtn) {
        // Add a pulsing animation to draw attention
        markIncompleteBtn.style.animation = 'pulse 2s infinite';
        
        // Add CSS for the pulse animation
        const style = document.createElement('style');
        style.textContent = `
            @keyframes pulse {
                0% { box-shadow: 0 0 0 0 rgba(255, 193, 7, 0.7); }
                70% { box-shadow: 0 0 0 10px rgba(255, 193, 7, 0); }
                100% { box-shadow: 0 0 0 0 rgba(255, 193, 7, 0); }
            }
        `;
        document.head.appendChild(style);
    }
}

// Handle grading notes collapse toggle icon
const gradingNotesCollapse = document.getElementById('gradingNotesCollapse');
const gradingNotesToggleIcon = document.getElementById('gradingNotesToggleIcon');

gradingNotesCollapse.addEventListener('show.bs.collapse', function () {
    gradingNotesToggleIcon.classList.remove('bi-chevron-down');
    gradingNotesToggleIcon.classList.add('bi-chevron-up');
});

gradingNotesCollapse.addEventListener('hide.bs.collapse', function () {
    gradingNotesToggleIcon.classList.remove('bi-chevron-up');
    gradingNotesToggleIcon.classList.add('bi-chevron-down');
});

// Auto-save grading notes
const gradingNotesField = document.getElementById('grading-notes');
let notesTimeout;

function saveGradingNotes() {
    const formData = new FormData();
    formData.append('grader_notes', gradingNotesField.value);
    formData.append('session_id', '{{ session.id }}');
    formData.append('csrfmiddlewaretoken', document.querySelector('[name=csrfmiddlewaretoken]').value);

    return fetch('{% url "questions:save_grading_notes" question.pk %}', {
        method: 'POST',
        body: formData,
        headers: {
            'X-Requested-With': 'XMLHttpRequest',
        }
    })
    .then(response => response.json())
    .then(data => {
        if (!data.success) {
            console.error('Failed to save grading notes:', data.error);
        }
        return data;
    })
    .catch(error => {
        console.error('Error saving grading notes:', error);
        return { success: false, error: error };
    });
}

let hasNotesChanges = false;

// Only enable auto-save for notes if session is not finalized
if (!isSessionFinalized) {
    gradingNotesField.addEventListener('input', function() {
        clearTimeout(notesTimeout);
        hasNotesChanges = true;
        notesTimeout = setTimeout(() => {
            saveGradingNotes();
            hasNotesChanges = false;
        }, 2000);  // Save after 2 seconds of no typing
    });
}

// Handle N/A toggle for Correct End Result
const naToggle = document.getElementById('na_toggle');
const correctResultButtons = document.getElementById('correct_result_buttons');
const correctResultInputs = correctResultButtons.querySelectorAll('input[type="radio"]');
const correctResultLabels = correctResultButtons.querySelectorAll('label');

function updateNAState() {
    // Don't modify disabled state if grading is already disabled (completed/finalized)
    if (isGradingDisabled) {
        // Just ensure the N/A hidden field exists if needed, but don't change disabled states
        if (naToggle.checked) {
            // Set the hidden N/A value (state id 4)
            let hiddenInput = document.getElementById('achievement_correct_result_4');
            if (!hiddenInput) {
                hiddenInput = document.createElement('input');
                hiddenInput.type = 'hidden';
                hiddenInput.id = 'achievement_correct_result_4';
                hiddenInput.name = 'achievement_correct_result';
                hiddenInput.value = '4';
                correctResultButtons.appendChild(hiddenInput);
            }
        } else {
            // Remove the hidden N/A value
            const hiddenInput = document.getElementById('achievement_correct_result_4');
            if (hiddenInput) {
                hiddenInput.remove();
            }
        }
        return;
    }
    
    // Normal behavior when grading is not disabled
    if (naToggle.checked) {
        // Disable all buttons and add disabled class
        correctResultInputs.forEach(input => {
            input.disabled = true;
            input.checked = false;
        });
        correctResultLabels.forEach(label => {
            label.classList.add('disabled');
        });
        
        // Set the hidden N/A value (state id 4)
        let hiddenInput = document.getElementById('achievement_correct_result_4');
        if (!hiddenInput) {
            hiddenInput = document.createElement('input');
            hiddenInput.type = 'hidden';
            hiddenInput.id = 'achievement_correct_result_4';
            hiddenInput.name = 'achievement_correct_result';
            hiddenInput.value = '4';
            correctResultButtons.appendChild(hiddenInput);
        }
    } else {
        // Enable all buttons and remove disabled class
        correctResultInputs.forEach(input => {
            input.disabled = false;
        });
        correctResultLabels.forEach(label => {
            label.classList.remove('disabled');
        });
        
        // Remove the hidden N/A value
        const hiddenInput = document.getElementById('achievement_correct_result_4');
        if (hiddenInput) {
            hiddenInput.remove();
        }
    }
}

// Only add the change event listener if grading is not disabled
if (!isGradingDisabled) {
    naToggle.addEventListener('change', () => {
        updateNAState();
        
        // Toggle N/A for all other model answers to match this one
        const formData = new FormData();
        formData.append('csrfmiddlewaretoken', document.querySelector('[name=csrfmiddlewaretoken]').value);
        formData.append('toggle_na_action', naToggle.checked ? 'enable' : 'disable');
        formData.append('session_id', '{{ session.id }}');

        fetch('{% url "questions:toggle_na_for_all" question.pk %}', {
            method: 'POST',
            body: formData,
            headers: {
                'X-Requested-With': 'XMLHttpRequest',
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success && data.message) {
                // Show a subtle notification that other answers were updated
                const notification = document.createElement('div');
                notification.className = 'alert alert-info py-1 px-2 text-center small position-fixed top-0 start-50 translate-middle-x mt-3';
                notification.style.zIndex = '9999';
                notification.innerHTML = '<i class="bi bi-info-circle me-1"></i> ' + data.message;
                document.body.appendChild(notification);
                setTimeout(() => notification.remove(), 3000);
            }
        })
        .catch(error => console.error('Error toggling N/A for all:', error));
        
        autoSave();
    });
}

// Initialize N/A state on page load
updateNAState();

// Auto-save functionality
let saveTimeout;
let hasPendingChanges = false;
let isSaving = false;
const form = document.getElementById('grading-form');
const saveIndicator = document.getElementById('save-indicator');

function showSaveStatus(status, message) {
    saveIndicator.className = 'alert py-1 px-2 text-center small';
    
    if (status === 'saving') {
        saveIndicator.classList.add('alert-warning');
        saveIndicator.innerHTML = '<i class="bi bi-cloud-arrow-up me-1"></i> Saving...';
    } else if (status === 'saved') {
        saveIndicator.classList.add('alert-success');
        saveIndicator.innerHTML = '<i class="bi bi-cloud-check me-1"></i> ' + message;
    } else if (status === 'error') {
        saveIndicator.classList.add('alert-danger');
        saveIndicator.innerHTML = '<i class="bi bi-cloud-slash me-1"></i> ' + message;
    }
}

function autoSave() {
    clearTimeout(saveTimeout);
    hasPendingChanges = true;
    saveTimeout = setTimeout(() => {
        saveGrading();
    }, 2000);  // Save 2 seconds after last change
}

function saveGrading(markComplete = false, giveUp = false, markIncomplete = false) {
    if (isSaving) {
        // If already saving, queue another save after current one completes
        setTimeout(() => saveGrading(markComplete, giveUp, markIncomplete), 100);
        return Promise.resolve();
    }
    
    isSaving = true;
    hasPendingChanges = false;
    clearTimeout(saveTimeout);
    showSaveStatus('saving', 'Saving...');
    
    const formData = new FormData(form);
    if (markComplete) {
        formData.append('mark_complete', 'true');
    }
    if (giveUp) {
        formData.append('give_up', 'true');
    }
    if (markIncomplete) {
        formData.append('mark_incomplete', 'true');
    }
    
    return fetch('', {
        method: 'POST',
        body: formData,
        headers: {
            'X-Requested-With': 'XMLHttpRequest',
        }
    })
    .then(response => response.json())
    .then(data => {
        isSaving = false;
        if (data.success) {
            showSaveStatus('saved', 'Saved successfully');
            
            // If marking complete and there's a next URL, navigate to it
            if (markComplete && data.next_url) {
                setTimeout(() => {
                    window.location.href = data.next_url;
                }, 500);
            }
            // Otherwise, update tab status if status changed
            else if (markComplete || giveUp || markIncomplete) {
                setTimeout(() => {
                    location.reload();  // Reload to update tab statuses and buttons
                }, 1000);
            }
        } else {
            showSaveStatus('error', 'Save failed: ' + data.error);
        }
    })
    .catch(error => {
        isSaving = false;
        showSaveStatus('error', 'Save failed: ' + error);
    });
}

// Save immediately when leaving the page
function saveBeforeLeaving() {
    const promises = [];
    
    // Clear any pending timeouts
    if (saveTimeout) {
        clearTimeout(saveTimeout);
    }
    if (notesTimeout) {
        clearTimeout(notesTimeout);
    }
    
    // Save grading if there are pending changes
    if (hasPendingChanges) {
        promises.push(saveGrading());
    }
    
    // Save notes if there are pending changes
    if (hasNotesChanges) {
        promises.push(saveGradingNotes());
        hasNotesChanges = false;
    }
    
    if (promises.length > 0) {
        return Promise.all(promises);
    }
    return Promise.resolve();
}

// Add event listeners for auto-save (only if grading is not disabled)
if (!isGradingDisabled) {
    form.querySelectorAll('input, textarea').forEach(element => {
        element.addEventListener('change', autoSave);
        element.addEventListener('input', autoSave);
    });
}

// Mark complete button
const markCompleteBtn = document.getElementById('mark-complete-btn');
if (markCompleteBtn) {
    markCompleteBtn.addEventListener('click', () => {
        // Check if all categories have been graded (not NULL)
        const requiredFields = [
            'error_incorrect_logic',
            'error_hallucinated', 
            'error_calculation',
            'error_conceptual',
            'achievement_understanding',
            'achievement_insight',
            'achievement_usefulness',
            'progress_grade'
        ];
        
        // Special handling for achievement_correct_result (can be N/A)
        const correctResultField = naToggle.checked ? 
            document.getElementById('achievement_correct_result_4') : 
            document.querySelector('input[name="achievement_correct_result"]:checked');
        
        const missingFields = [];
        for (const fieldName of requiredFields) {
            const field = document.querySelector(`input[name="${fieldName}"]:checked`);
            if (!field) {
                // Convert field name to readable format
                const readableName = fieldName
                    .replace('error_', '')
                    .replace('achievement_', '')
                    .replace('_', ' ')
                    .replace(/\b\w/g, l => l.toUpperCase());
                missingFields.push(readableName);
            }
        }
        
        // Check correct result separately
        if (!correctResultField) {
            missingFields.push('Correct End Result');
        }
        
        if (missingFields.length > 0) {
            alert('Please complete all grading categories before marking as complete.\n\nMissing categories:\n• ' + 
                  missingFields.join('\n• ') + 
                  '\n\nYou must select at least "Not Sure" for each category.');
            return;
        }
        
        if (confirm('Mark this grading as complete? You can still edit it later.')) {
            saveGrading(true, false);
        }
    });
}

// Mark incomplete button
const markIncompleteBtn = document.getElementById('mark-incomplete-btn');
if (markIncompleteBtn) {
    markIncompleteBtn.addEventListener('click', () => {
        saveGrading(false, false, true);  // Third parameter for marking incomplete
    });
}

// Give up button
const giveUpBtn = document.getElementById('give-up-btn');
if (giveUpBtn && !giveUpBtn.disabled) {
    giveUpBtn.addEventListener('click', () => {
        if (confirm('Give up on grading this answer? This will mark it as "given up" and you can move to the next answer.')) {
            saveGrading(false, true);
        }
    });
}

// Keyboard shortcuts
document.addEventListener('keydown', (e) => {
    // Ctrl+S to save
    if (e.ctrlKey && e.key === 's') {
        e.preventDefault();
        saveGrading();
    }
});

// Save on blur (when field loses focus) for immediate save
if (!isGradingDisabled) {
    form.querySelectorAll('input, textarea').forEach(element => {
        element.addEventListener('blur', () => {
            if (hasPendingChanges) {
                clearTimeout(saveTimeout);
                saveGrading();
            }
        });
    });
}

// Also save grading notes on blur
if (!isSessionFinalized) {
    gradingNotesField.addEventListener('blur', () => {
        if (hasNotesChanges) {
            clearTimeout(notesTimeout);
            saveGradingNotes();
            hasNotesChanges = false;
        }
    });
}

// Intercept tab navigation clicks to save before switching
document.querySelectorAll('.nav-pills .nav-link').forEach(link => {
    link.addEventListener('click', (e) => {
        // Only intercept if there are pending changes and it's not the current tab
        if ((hasPendingChanges || hasNotesChanges) && !link.classList.contains('active')) {
            e.preventDefault();
            const targetUrl = link.href;
            
            // Save before navigating
            saveBeforeLeaving().then(() => {
                window.location.href = targetUrl;
            });
        }
    });
});

// Save when leaving the page entirely (browser navigation, closing tab, etc.)
window.addEventListener('beforeunload', (e) => {
    if (hasPendingChanges || hasNotesChanges) {
        // Try to save synchronously (best effort, may not complete)
        const formData = new FormData(form);
        navigator.sendBeacon('', formData);
        
        // Show warning to user (modern browsers show generic message)
        e.preventDefault();
        e.returnValue = 'You have unsaved changes. Are you sure you want to leave?';
        return e.returnValue;
    }
});

// Alternative: Use page visibility API for more reliable saves
document.addEventListener('visibilitychange', () => {
    if (document.hidden && (hasPendingChanges || hasNotesChanges)) {
        // Page is being hidden (tab switch, minimize, etc.)
        saveBeforeLeaving();
    }
});
</script>
{% endblock %}