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

{% block title %}
    {% if form.instance.pk %}Edit Question{% else %}Add Question{% endif %} - IMProofBench
{% endblock %}

{% block page_header %}
<div class="mb-4">
    <div class="d-flex justify-content-between align-items-center">
        <nav aria-label="breadcrumb">
            <ol class="breadcrumb mb-0">
                <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>
                {% if form.instance.pk %}
                <li class="breadcrumb-item">
                    <a href="{% url 'questions:detail' form.instance.pk %}" class="text-decoration-none">
                        {{ form.instance.title|truncatechars:30 }}
                    </a>
                </li>
                <li class="breadcrumb-item active">Edit</li>
                {% else %}
                <li class="breadcrumb-item active">Add New</li>
                {% endif %}
            </ol>
        </nav>
        {% if form.instance.pk %}
        <a href="{% url 'questions:history' form.instance.pk %}" class="btn btn-outline-secondary btn-sm">
            <i class="bi bi-clock-history me-1"></i> View History
        </a>
        {% endif %}
    </div>
</div>
{% endblock %}

{% block content %}
<div class="row">
    <div class="col-12">
        {% if form.instance.pk and subquestion_evaluation_count %}
        <div class="alert alert-danger border-3 border-danger shadow-sm d-flex align-items-start" role="alert" style="background-color: #fff5f5; border-left-width: 5px !important;">
            <i class="bi bi-exclamation-triangle-fill text-danger fs-3 me-3 mt-1"></i>
            <div>
                <h5 class="alert-heading text-danger mb-2">
                    <strong>Heads up:</strong>
                </h5>
                <p class="mb-0">
                    This question has {{ subquestion_evaluation_count }} recorded subquestion evaluation{{ subquestion_evaluation_count|pluralize }}.
                    Editing subquestions may invalidate existing evaluation data. Please do not modify the subquestions if you are not 100% sure you know what this means. Otherwise, please contact an admin before proceeding.
                </p>
            </div>
        </div>
        {% endif %}
        <!-- Question Form -->
        <div class="question-editor">
            {% crispy form %}
        </div>
    </div>
</div>
{% endblock %}

{% block extra_css %}
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.10.0/font/bootstrap-icons.css">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/simplemde/latest/simplemde.min.css">
<style>
    /* Custom styling for question editor */
    .question-editor {
        background: white;
        border-radius: 12px;
        box-shadow: 0 2px 10px rgba(0,0,0,0.1);
        overflow: hidden;
    }
    
    .card {
        border: 1px solid #e9ecef;
        border-radius: 8px;
        box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    }
    
    .card-header {
        background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%);
        border-bottom: 1px solid #dee2e6;
        font-weight: 600;
    }
    
    /* Form field styling */
    .form-control-lg {
        border-radius: 8px;
        border: 2px solid #e9ecef;
        transition: all 0.2s ease;
        font-size: 1.1rem;
    }
    
    .form-control-lg:focus {
        border-color: #0d6efd;
        box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.15);
    }
    
    .form-select {
        border-radius: 6px;
        border: 1px solid #ced4da;
    }
    
    .form-select:focus {
        border-color: #0d6efd;
        box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.15);
    }
    
    /* Button styling */
    .btn-lg {
        border-radius: 8px;
        font-weight: 600;
        letter-spacing: 0.5px;
        padding: 12px 24px;
    }

    /* SimpleMDE editor styling */
    .CodeMirror {
        border: 1px solid #dee2e6;
        border-radius: 0 0 8px 8px;
        min-height: 300px;
        font-size: 14px;
    }

    .editor-toolbar {
        border: 1px solid #dee2e6;
        border-bottom: none;
        border-radius: 8px 8px 0 0;
        background-color: #f8f9fa;
    }

    .editor-preview-side,
    .editor-preview {
        border: 1px solid #dee2e6;
        padding: 15px;
        background-color: #ffffff;
    }

    /* Math rendering in SimpleMDE preview */
    .editor-preview mjx-container,
    .editor-preview-side mjx-container {
        font-size: 1.1em !important;
    }

    .editor-preview mjx-container[display="true"],
    .editor-preview-side mjx-container[display="true"] {
        display: block !important;
        text-align: center;
        margin: 1.5em 0;
        padding: 0.75em;
        background-color: #f8f9fa;
        border-radius: 0.5rem;
        border-left: 4px solid #0d6efd;
    }
    
    /* Subquestion styling */
    .subquestion-form {
        background: #fafafa;
        border: 1px solid #e9ecef !important;
        transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
    }
    
    .subquestion-form:hover {
        border-color: #0d6efd !important;
        box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.1);
    }
    
    .subquestion-letter {
        font-weight: 600;
        font-size: 1.1em;
    }
    
    .remove-subquestion:hover {
        transform: scale(1.05);
    }
    
    /* Breadcrumb styling */
    .breadcrumb {
        background: none;
        padding: 0;
        margin: 0;
        font-size: 0.9rem;
    }
    
    .breadcrumb-item + .breadcrumb-item::before {
        content: "›";
        color: #6c757d;
    }
    
    /* Form validation styling */
    .is-invalid {
        border-color: #dc3545;
    }
    
    .invalid-feedback {
        display: block;
        font-size: 0.875rem;
        margin-top: 0.25rem;
    }
    
    /* Fix Save as Draft button styling */
    .btn-outline-primary {
        color: #0d6efd !important;
        background-color: transparent !important;
        border-color: #0d6efd !important;
    }
    
    .btn-outline-primary:hover {
        color: #fff !important;
        background-color: #0d6efd !important;
        border-color: #0d6efd !important;
    }
    
    /* Success state styling */
    .is-valid {
        border-color: #198754;
    }
    
    /* Help text styling */
    .form-text {
        color: #6c757d;
        font-size: 0.875rem;
        margin-top: 0.25rem;
    }
    
    /* Difficulty rating section */
    .difficulty-section .form-label {
        font-weight: 600;
        margin-bottom: 0.5rem;
        color: #495057;
    }
    
    /* Loading state for martor */
    .martor-preview.loading {
        opacity: 0.7;
        background: #f8f9fa;
    }
    
    .martor-preview.loading::before {
        content: "Rendering preview...";
        color: #6c757d;
        font-style: italic;
    }
    
    /* Fix button width to prevent layout shifts during state changes */
    #save-current-draft {
        min-width: 160px; /* Match "Save and Exit" button width exactly */
        transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
    }
    
    /* Ensure consistent button widths for both Save buttons */
    .btn-lg.px-4 {
        min-width: 160px; /* Match Save button width */
    }
    
    /* AI Response Markdown Styling */
    #ai-response-content {
        line-height: 1.6;
        color: #333;
    }
    
    #ai-response-content h1,
    #ai-response-content h2,
    #ai-response-content h3,
    #ai-response-content h4,
    #ai-response-content h5,
    #ai-response-content h6 {
        margin-top: 1.5rem;
        margin-bottom: 0.75rem;
        font-weight: 600;
        color: #2c3e50;
    }
    
    #ai-response-content h1 { font-size: 1.75rem; }
    #ai-response-content h2 { font-size: 1.5rem; }
    #ai-response-content h3 { font-size: 1.25rem; }
    
    #ai-response-content p {
        margin-bottom: 1rem;
    }
    
    #ai-response-content ul,
    #ai-response-content ol {
        margin-bottom: 1rem;
        padding-left: 1.5rem;
    }
    
    #ai-response-content li {
        margin-bottom: 0.25rem;
    }
    
    #ai-response-content code {
        background-color: #f8f9fa;
        padding: 0.2rem 0.4rem;
        border-radius: 0.25rem;
        font-size: 0.875rem;
        color: #e83e8c;
    }
    
    #ai-response-content pre {
        background-color: #f8f9fa;
        padding: 1rem;
        border-radius: 0.5rem;
        overflow-x: auto;
        margin-bottom: 1rem;
    }
    
    #ai-response-content blockquote {
        border-left: 4px solid #dee2e6;
        padding-left: 1rem;
        margin: 1rem 0;
        color: #6c757d;
        font-style: italic;
    }
    
    /* Math content styling - MathJax enhancement */
    #ai-response-content .MathJax {
        font-size: 1.1em !important;
        color: #2c3e50 !important;
    }
    
    #ai-response-content .MathJax_Display {
        text-align: center !important;
        margin: 1.5em 0 !important;
        padding: 0.75em !important;
        background-color: #f8f9fa;
        border-radius: 0.5rem;
        border-left: 4px solid #0d6efd;
    }
    
    #ai-response-content .MathJax_Display .MathJax {
        font-size: 1.3em !important;
    }
    
    /* Inline math styling */
    #ai-response-content .MathJax:not(.MathJax_Display) {
        background-color: rgba(13, 110, 253, 0.05);
        padding: 0.15em 0.3em;
        border-radius: 0.25rem;
        margin: 0 0.1em;
    }
    
    /* MathJax v3 SVG styling */
    #ai-response-content mjx-container {
        display: inline-block;
        font-size: 1.1em;
        color: #2c3e50;
    }
    
    #ai-response-content mjx-container[display="true"] {
        display: block !important;
        text-align: center;
        margin: 1.5em 0;
        padding: 0.75em;
        background-color: #f8f9fa;
        border-radius: 0.5rem;
        border-left: 4px solid #0d6efd;
    }
    
    /* Inline mjx-container styling */
    #ai-response-content mjx-container:not([display="true"]) {
        background-color: rgba(13, 110, 253, 0.05);
        padding: 0.1em 0.25em;
        border-radius: 0.25rem;
        margin: 0 0.1em;
    }
    
    /* Fix text selection in subquestion inputs */
    .subquestion-form textarea,
    .subquestion-form input[type="text"],
    .subquestion-form input[type="number"] {
        -webkit-user-select: text !important;
        -moz-user-select: text !important;
        -ms-user-select: text !important;
        user-select: text !important;
    }
    
    /* Ensure drag handle is the only draggable element */
    .drag-handle {
        -webkit-user-select: none;
        -moz-user-select: none;
        -ms-user-select: none;
        user-select: none;
    }
    
    /* Visual feedback for drag handle on hover */
    .drag-handle:hover {
        color: #0d6efd !important;
        cursor: grab;
    }
    
    .drag-handle:active {
        cursor: grabbing;
    }
</style>
{% endblock %}

{% block extra_js %}
<!-- SimpleMDE editor -->
<script src="https://cdn.jsdelivr.net/simplemde/latest/simplemde.min.js"></script>

<script>

document.addEventListener('DOMContentLoaded', function() {
    console.log('Question form loaded');

    // Helper function to sync all SimpleMDE editors back to their textareas
    // This must be called before any FormData collection or direct textarea value reads
    function syncSimpleMDEEditors() {
        // Find all textareas and check if they have a SimpleMDE instance attached
        document.querySelectorAll('textarea').forEach(function(textarea) {
            if (textarea.simplemde) {
                // SimpleMDE stores the value in CodeMirror; sync it back to textarea
                var value = textarea.simplemde.value();
                textarea.value = value;
                console.log('Synced SimpleMDE for', textarea.name, '- length:', value.length);
            }
        });
    }

    // Make syncSimpleMDEEditors available globally for form submission
    window.syncSimpleMDEEditors = syncSimpleMDEEditors;

    // Page leave warning - prevent accidental loss of work
    let hasUnsavedChanges = true; // Always warn on create/edit pages
    
    // Clear warning when form is being saved
    const questionForm = document.querySelector('.question-form');
    if (questionForm) {
        questionForm.addEventListener('submit', function() {
            // Sync SimpleMDE editors to textareas before form submission
            syncSimpleMDEEditors();
            hasUnsavedChanges = false; // Allow form submission without warning
        });
    }
    
    // Show browser warning when trying to leave page
    window.addEventListener('beforeunload', function(event) {
        if (hasUnsavedChanges) {
            // Modern browsers ignore custom messages and show standard warning
            event.preventDefault();
            event.returnValue = ''; // Required for Chrome
            return ''; // Required for older browsers
        }
    });
    
    // Subquestion management
    let subquestionCount = 0;
    
    function addSubquestion() {
        const container = document.getElementById('subquestions-container');
        const noSubquestions = document.getElementById('no-subquestions');
        
        // Hide "no subquestions" message
        noSubquestions.style.display = 'none';
        
        // Create subquestion form HTML
        const subquestionHtml = `
            <div class="subquestion-form border rounded p-3 mb-3" data-subquestion="${subquestionCount}">
                <div class="d-flex justify-content-between align-items-center mb-3">
                    <div class="d-flex align-items-center gap-2">
                        <span class="text-secondary drag-handle" style="cursor:grab" title="Drag to reorder">
                            <i class="bi bi-grip-vertical"></i>
                        </span>
                        <h6 class="mb-0 text-primary">
                            <i class="bi bi-arrow-right-circle me-1"></i>
                            Subquestion <span class="subquestion-letter">${String.fromCharCode(97 + subquestionCount)}</span>
                        </h6>
                    </div>
                    <div class="btn-group">
                        <button type="button" class="btn btn-outline-secondary btn-sm move-up" title="Move up">
                            <i class="bi bi-arrow-up"></i>
                        </button>
                        <button type="button" class="btn btn-outline-secondary btn-sm move-down" title="Move down">
                            <i class="bi bi-arrow-down"></i>
                        </button>
                        <button type="button" class="btn btn-outline-danger btn-sm remove-subquestion" title="Remove">
                            <i class="bi bi-trash"></i>
                        </button>
                    </div>
                </div>
                
                <div class="row">
                    <div class="col-md-8">
                        <div class="mb-3">
                            <label class="form-label">Question Text *</label>
                            <textarea class="form-control" name="subquestion_${subquestionCount}_text" rows="3" 
                                placeholder="Enter the subquestion text..." required></textarea>
                            <div class="form-text">Required: The subquestion text (supports basic Markdown)</div>
                        </div>
                    </div>
                    <div class="col-md-4">
                        <div class="mb-3">
                            <label class="form-label">Expected Answer *</label>
                            <input type="text" class="form-control" name="subquestion_${subquestionCount}_answer" 
                                placeholder="Expected answer" required>
                            <div class="form-text">Required: Exact answer expected</div>
                        </div>
                    </div>
                </div>
                
                <div class="row">
                    <div class="col-md-6">
                        <div class="mb-3">
                            <label class="form-label">Evaluation Method *</label>
                            <select class="form-select" name="subquestion_${subquestionCount}_evaluation_type" required>
                                <option value="1">Exact Match</option>
                            </select>
                            <div class="form-text">Required: How answers will be evaluated</div>
                        </div>
                    </div>
                    <div class="col-md-3">
                        <div class="mb-3">
                            <label class="form-label">Points (Optional)</label>
                            <input type="number" class="form-control" name="subquestion_${subquestionCount}_points" 
                                placeholder="1" min="1">
                            <div class="form-text">Optional: Defaults to 1</div>
                        </div>
                    </div>
                </div>
                
                <div class="mb-0">
                    <label class="form-label">Rationale (Optional)</label>
                    <textarea class="form-control" name="subquestion_${subquestionCount}_rationale" rows="2" 
                        placeholder="Explanation of why this is the correct answer..."></textarea>
                    <div class="form-text">Optional: Explanation of the correct answer</div>
                </div>
            </div>
        `;
        
        // Add to container
        container.insertAdjacentHTML('beforeend', subquestionHtml);
        subquestionCount++;
        
        // Initialize DnD handlers and renumber
        initDnDHandlers();
        renumberSubquestions();
        
        // Scroll to the newly added subquestion
        setTimeout(() => {
            const newSubquestion = container.lastElementChild;
            if (newSubquestion) {
                newSubquestion.scrollIntoView({ behavior: 'smooth', block: 'center' });
                // Focus on the first input field for immediate editing
                const firstInput = newSubquestion.querySelector('textarea, input[type="text"]');
                if (firstInput) {
                    setTimeout(() => firstInput.focus(), 500);
                }
            }
        }, 50);
    }
    
    function removeSubquestion(element) {
        element.closest('.subquestion-form').remove();
        renumberSubquestions();
        
        // Show "no subquestions" message if none left
        const container = document.getElementById('subquestions-container');
        const noSubquestions = document.getElementById('no-subquestions');
        if (container.children.length === 0) {
            noSubquestions.style.display = 'block';
        }
    }
    
    function updateSubquestionLetters() {
        const subquestionForms = document.querySelectorAll('.subquestion-form');
        subquestionForms.forEach((form, index) => {
            const letter = String.fromCharCode(97 + index); // a, b, c, etc.
            const letterSpan = form.querySelector('.subquestion-letter');
            if (letterSpan) {
                letterSpan.textContent = letter;
            }
        });
    }
    
    function loadExistingSubquestions(subquestions) {
        const container = document.getElementById('subquestions-container');
        const noSubquestions = document.getElementById('no-subquestions');
        
        // Hide "no subquestions" message
        noSubquestions.style.display = 'none';
        
        subquestions.forEach((subq, index) => {
            // Create subquestion form HTML with existing data
            const subquestionHtml = `
                <div class="subquestion-form border rounded p-3 mb-3" data-subquestion="${index}">
                    <div class="d-flex justify-content-between align-items-center mb-3">
                        <div class="d-flex align-items-center gap-2">
                            <span class="text-secondary drag-handle" style="cursor:grab" title="Drag to reorder">
                                <i class="bi bi-grip-vertical"></i>
                            </span>
                            <h6 class="mb-0 text-primary">
                                <i class="bi bi-arrow-right-circle me-1"></i>
                                Subquestion <span class="subquestion-letter">${subq.subquestion_order}</span>
                            </h6>
                        </div>
                        <div class="btn-group">
                            <button type="button" class="btn btn-outline-secondary btn-sm move-up" title="Move up">
                                <i class="bi bi-arrow-up"></i>
                            </button>
                            <button type="button" class="btn btn-outline-secondary btn-sm move-down" title="Move down">
                                <i class="bi bi-arrow-down"></i>
                            </button>
                            <button type="button" class="btn btn-outline-danger btn-sm remove-subquestion" title="Remove">
                                <i class="bi bi-trash"></i>
                            </button>
                        </div>
                    </div>
                    
                    <input type="hidden" name="subquestion_${index}_id" value="${subq.id}">

                    <div class="row">
                        <div class="col-md-8">
                            <div class="mb-3">
                                <label class="form-label">Question Text *</label>
                                <textarea class="form-control" name="subquestion_${index}_text" rows="3" 
                                    placeholder="Enter the subquestion text..." required>${subq.text || ''}</textarea>
                                <div class="form-text">Required: The subquestion text (supports basic Markdown)</div>
                            </div>
                        </div>
                        <div class="col-md-4">
                            <div class="mb-3">
                                <label class="form-label">Expected Answer *</label>
                                <input type="text" class="form-control" name="subquestion_${index}_answer" 
                                    placeholder="Expected answer" value="${subq.answer || ''}" required>
                                <div class="form-text">Required: Exact answer expected</div>
                            </div>
                        </div>
                    </div>
                    
                    <div class="row">
                        <div class="col-md-6">
                            <div class="mb-3">
                                <label class="form-label">Evaluation Method *</label>
                                <select class="form-select" name="subquestion_${index}_evaluation_type" required>
                                    <option value="1" ${subq.evaluation_type_id == 1 ? 'selected' : ''}>Exact Match</option>
                                </select>
                                <div class="form-text">Required: How answers will be evaluated</div>
                            </div>
                        </div>
                        <div class="col-md-3">
                            <div class="mb-3">
                                <label class="form-label">Points (Optional)</label>
                                <input type="number" class="form-control" name="subquestion_${index}_points" 
                                    placeholder="1" min="1" value="${subq.points || ''}">
                                <div class="form-text">Optional: Defaults to 1</div>
                            </div>
                        </div>
                    </div>
                    
                    <div class="mb-0">
                        <label class="form-label">Rationale (Optional)</label>
                        <textarea class="form-control" name="subquestion_${index}_rationale" rows="2" 
                            placeholder="Explanation of why this is the correct answer...">${subq.rationale || ''}</textarea>
                        <div class="form-text">Optional: Explanation of the correct answer</div>
                    </div>
                </div>
            `;
            
            // Add to container
            container.insertAdjacentHTML('beforeend', subquestionHtml);
        });
        
        // Update subquestion count for new additions
        subquestionCount = subquestions.length;
    }
    
    // Event listeners for subquestions
    document.getElementById('add-subquestion').addEventListener('click', addSubquestion);
    
    // Event delegation for remove / move buttons
    document.addEventListener('click', function(e) {
        if (e.target.closest('.remove-subquestion')) {
            removeSubquestion(e.target);
            return;
        }
        if (e.target.closest('.move-up')) {
            const block = e.target.closest('.subquestion-form');
            if (block && block.previousElementSibling) {
                block.parentNode.insertBefore(block, block.previousElementSibling);
                renumberSubquestions();
                
                // Scroll the moved block into view, centered if possible
                setTimeout(() => {
                    block.scrollIntoView({ behavior: 'smooth', block: 'center' });
                }, 50);
            }
            return;
        }
        if (e.target.closest('.move-down')) {
            const block = e.target.closest('.subquestion-form');
            if (block && block.nextElementSibling) {
                block.parentNode.insertBefore(block.nextElementSibling, block);
                renumberSubquestions();
                
                // Scroll the moved block into view, centered if possible
                setTimeout(() => {
                    block.scrollIntoView({ behavior: 'smooth', block: 'center' });
                }, 50);
            }
            return;
        }
    });
    
    // Load existing subquestions if editing
    {% if existing_subquestions_json %}
        const existingSubquestions = {{ existing_subquestions_json|safe }};
        loadExistingSubquestions(existingSubquestions);
        initDnDHandlers();
        renumberSubquestions();
    {% else %}
        // Show "no subquestions" message initially for new questions
        document.getElementById('no-subquestions').style.display = 'block';
    {% endif %}
    
    // Form validation enhancements
    const form = document.querySelector('.question-form');
    if (form) {
        // Real-time validation for title
        const titleInput = form.querySelector('input[name="title"]');
        if (titleInput) {
            titleInput.addEventListener('input', function() {
                const value = this.value.trim();
                this.classList.remove('is-valid', 'is-invalid');
                
                if (value.length >= 5 && value.length <= 200) {
                    this.classList.add('is-valid');
                } else if (value.length > 0) {
                    this.classList.add('is-invalid');
                }
            });
        }
        
        // Form submission handling
        form.addEventListener('submit', function(e) {
            // Ensure indices reflect visual order before submit
            renumberSubquestions();
            const submitButton = e.submitter;
            if (submitButton) {
                submitButton.disabled = true;
                submitButton.innerHTML = '<i class="bi bi-hourglass-split me-1"></i>Saving...';
                
                // Re-enable button after a delay in case of validation errors
                setTimeout(function() {
                    submitButton.disabled = false;
                    if (submitButton.name === 'save') {
                        submitButton.innerHTML = '{% if form.instance.pk %}Save and Exit{% else %}Save Question{% endif %}';
                    }
                }, 5000);
            }
        });
    }
    
    // Auto-save functionality (every 30 seconds for drafts)
    let autoSaveTimer;
    const autoSaveInterval = 30000; // 30 seconds
    
    function enableAutoSave() {
        autoSaveTimer = setInterval(function() {
            // Only auto-save if form has been modified
            const form = document.querySelector('.question-form');
            if (form && form.querySelector('.is-valid, .is-invalid')) {
                console.log('Auto-save triggered (placeholder for future implementation)');
                // Future: Implement AJAX auto-save for drafts
            }
        }, autoSaveInterval);
    }
    
    // Start auto-save after user starts typing
    document.addEventListener('input', function() {
        if (!autoSaveTimer) {
            enableAutoSave();
        }
    }, { once: true });
    
    // Clear auto-save timer when leaving page
    window.addEventListener('beforeunload', function() {
        if (autoSaveTimer) {
            clearInterval(autoSaveTimer);
        }
    });
    
    // AJAX Save functionality
    const saveCurrentBtn = document.getElementById('save-current-draft');
    if (saveCurrentBtn) {
        saveCurrentBtn.addEventListener('click', function() {
            saveQuestionAjax();
        });
    }
    
    // Track current question ID (starts as null for new questions)
    let currentQuestionId = {% if form.instance.pk %}{{ form.instance.pk }}{% else %}null{% endif %};
    
    function saveQuestionAjax() {
        const form = document.querySelector('.question-form');
        const saveBtn = document.getElementById('save-current-draft');
        
        if (!form) {
            console.error('Form not found');
            return;
        }
        
        // Disable button and show loading state
        saveBtn.disabled = true;
        const originalHTML = saveBtn.innerHTML;
        saveBtn.innerHTML = '<i class="bi bi-hourglass-split me-1"></i>Saving...';
        
        // Ensure indices reflect visual order before collect
        renumberSubquestions();

        // Sync SimpleMDE editors to textareas before collecting form data
        syncSimpleMDEEditors();

        // Get form data
        const formData = new FormData(form);
        
        // Get CSRF token
        const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;
        
        // Determine URL based on whether this is create or update
        const ajaxUrl = currentQuestionId 
            ? `{% url 'questions:ajax_save_draft' 0 %}`.replace('0', currentQuestionId)
            : `{% url 'questions:ajax_save_create' %}`;
        
        // Make AJAX request
        fetch(ajaxUrl, {
            method: 'POST',
            body: formData,
            headers: {
                'X-CSRFToken': csrfToken,
                'X-Requested-With': 'XMLHttpRequest'
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success) {
                // Clear any existing field errors
                clearFieldErrors();
                
                // Show success message
                showMessage(data.message, 'success');
                
                // If this was a create operation, update page state
                if (!currentQuestionId && data.question_id) {
                    currentQuestionId = data.question_id;
                    updatePageAfterCreation(data);
                }
                
                // Reset unsaved changes warning
                hasUnsavedChanges = false;
                setTimeout(() => { hasUnsavedChanges = true; }, 1000);
                
                // Show success state on button
                showButtonSuccess(saveBtn, originalHTML);
                
            } else {
                // Show error message
                showMessage(data.message, 'danger');
                
                // Display specific field errors
                if (data.errors) {
                    displayFieldErrors(data.errors);
                    console.error('Form errors:', data.errors);
                }
                
                // Reset button immediately on error
                saveBtn.disabled = false;
                saveBtn.innerHTML = originalHTML;
            }
        })
        .catch(error => {
            console.error('AJAX Error:', error);
            showMessage('❌ Network error occurred. Please try again.', 'danger');
            
            // Reset button immediately on error
            saveBtn.disabled = false;
            saveBtn.innerHTML = originalHTML;
        });
    }

    // Reordering helpers
    function renumberSubquestions() {
        const container = document.getElementById('subquestions-container');
        const blocks = Array.from(container.querySelectorAll('.subquestion-form'));
        if (blocks.length === 0) {
            document.getElementById('no-subquestions').style.display = 'block';
            return;
        }
        document.getElementById('no-subquestions').style.display = 'none';
        blocks.forEach((block, idx) => {
            block.dataset.subquestion = idx;
            // Update letter display
            const letterEl = block.querySelector('.subquestion-letter');
            if (letterEl) letterEl.textContent = String.fromCharCode(97 + (idx % 26));
            // Update field names
            block.querySelectorAll('[name^="subquestion_"]').forEach(input => {
                input.name = input.name.replace(/subquestion_\d+_/,'subquestion_' + idx + '_');
            });
        });
        subquestionCount = blocks.length; // keep counter in sync
    }

    function initDnDHandlers() {
        const container = document.getElementById('subquestions-container');
        const blocks = Array.from(container.querySelectorAll('.subquestion-form'));
        let dragged = null;
        
        blocks.forEach(block => {
            // Find the drag handle for this block
            const dragHandle = block.querySelector('.drag-handle');
            if (dragHandle) {
                // Make only the handle draggable
                dragHandle.setAttribute('draggable', 'true');
                
                // Start drag when handle is dragged
                dragHandle.addEventListener('dragstart', function(e){
                    dragged = block;  // Store the whole block, not just the handle
                    block.classList.add('opacity-50');
                    e.dataTransfer.effectAllowed = 'move';
                    // Store a reference to identify the block being dragged
                    e.dataTransfer.setData('text/html', '');
                });
                
                // Clean up after drag ends
                dragHandle.addEventListener('dragend', function(){
                    block.classList.remove('opacity-50');
                    container.querySelectorAll('.drag-over').forEach(el=>el.classList.remove('drag-over'));
                });
            }
            
            // These remain on the block itself for drop targeting
            block.addEventListener('dragover', function(e){
                if (dragged && dragged !== this) {
                    e.preventDefault();
                    this.classList.add('drag-over');
                }
            });
            
            block.addEventListener('dragleave', function(){
                this.classList.remove('drag-over');
            });
            
            block.addEventListener('drop', function(e){
                if (dragged && dragged !== this) {
                    e.preventDefault();
                    this.classList.remove('drag-over');
                    const nodes = Array.from(container.children);
                    const srcIndex = nodes.indexOf(dragged);
                    const tgtIndex = nodes.indexOf(this);
                    if (srcIndex < tgtIndex) {
                        container.insertBefore(dragged, this.nextSibling);
                    } else {
                        container.insertBefore(dragged, this);
                    }
                    renumberSubquestions();
                    dragged = null;
                }
            });
        });
    }
    
    function showButtonSuccess(button, originalHTML) {
        // Show success state for 1 second
        button.innerHTML = '<i class="bi bi-check-circle me-1"></i>Saved!';
        button.className = button.className.replace('btn-outline-primary', 'btn-success');
        
        setTimeout(() => {
            // Return to original state
            button.disabled = false;
            button.innerHTML = originalHTML;
            button.className = button.className.replace('btn-success', 'btn-outline-primary');
        }, 1000);
    }
    
    function updatePageAfterCreation(data) {
        // Update page title and breadcrumbs to show we're now editing
        const titleElement = document.querySelector('title');
        if (titleElement) {
            titleElement.textContent = 'Edit Question - IMProofBench';
        }
        
        // Update form title if present
        const formTitle = document.querySelector('h3');
        if (formTitle && formTitle.textContent.includes('Create')) {
            formTitle.textContent = 'Edit Question';
        }
        
        // Update the main "Save Question" button text to "Save and Exit"
        const saveExitBtn = document.querySelector('input[name="save"]');
        if (saveExitBtn) {
            saveExitBtn.value = 'Save and Exit';
        }
        
        // Update browser URL without page refresh
        if (history.pushState && data.edit_url) {
            history.pushState(null, '', data.edit_url);
        }
    }
    
    function displayFieldErrors(errors) {
        // Clear any existing error states
        clearFieldErrors();
        
        // Display errors for each field
        Object.keys(errors).forEach(fieldName => {
            const fieldElement = document.querySelector(`[name="${fieldName}"]`);
            const errorMessages = Array.isArray(errors[fieldName]) ? errors[fieldName] : [errors[fieldName]];
            
            if (fieldElement) {
                // Add error styling to field
                fieldElement.classList.add('is-invalid');
                fieldElement.classList.remove('is-valid');
                
                // Find or create error message container
                let errorContainer = fieldElement.parentNode.querySelector('.invalid-feedback');
                if (!errorContainer) {
                    errorContainer = document.createElement('div');
                    errorContainer.className = 'invalid-feedback';
                    fieldElement.parentNode.appendChild(errorContainer);
                }
                
                // Set error message
                errorContainer.innerHTML = errorMessages.join('<br>');
                errorContainer.style.display = 'block';
                
                // Scroll to first error field
                if (Object.keys(errors)[0] === fieldName) {
                    fieldElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
                }
            }
        });
    }
    
    function clearFieldErrors() {
        // Remove error styling from all fields
        document.querySelectorAll('.is-invalid').forEach(element => {
            element.classList.remove('is-invalid');
        });
        
        // Hide all error messages
        document.querySelectorAll('.invalid-feedback').forEach(element => {
            element.style.display = 'none';
        });
    }
    
    function showMessage(message, type) {
        // Remove existing ajax messages
        const existingMessages = document.querySelectorAll('.ajax-message');
        existingMessages.forEach(msg => msg.remove());
        
        // Create new message element
        const messageDiv = document.createElement('div');
        messageDiv.className = `alert alert-${type} alert-dismissible fade show ajax-message`;
        messageDiv.innerHTML = `
            ${message}
            <button type="button" class="btn-close" data-bs-dismiss="alert"></button>
        `;
        
        // Insert at the top of the main content
        const content = document.querySelector('main .container');
        if (content) {
            content.insertBefore(messageDiv, content.firstChild);
        }
        
        // Auto-dismiss success messages after 5 seconds
        if (type === 'success') {
            setTimeout(() => {
                if (messageDiv.parentNode) {
                    messageDiv.remove();
                }
            }, 5000);
        }
    }
    
    // ============================================================================
    // AI TESTING FUNCTIONALITY
    // ============================================================================
    
    // Load rate limit information on page load
    loadRateLimitInfo();
    
    // Test Question button click handler
    const testQuestionBtn = document.getElementById('test-question-btn');
    if (testQuestionBtn) {
        testQuestionBtn.addEventListener('click', function() {
            testQuestionWithAI();
        });
    }
    
    function loadRateLimitInfo() {
        fetch('/ai-testing/limits/', {
            method: 'GET',
            headers: {
                'X-Requested-With': 'XMLHttpRequest'
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success) {
                const remaining = data.limits.user_daily_remaining;
                const total = data.limits.user_daily_total;
                const resetTime = new Date(data.limits.reset_time);
                
                const rateLimitInfo = document.getElementById('rate-limit-info');
                if (rateLimitInfo) {
                    rateLimitInfo.innerHTML = `${remaining}/${total} tests remaining today (resets at midnight UTC)`;
                    
                    // Disable button if no tests remaining
                    if (remaining <= 0) {
                        testQuestionBtn.disabled = true;
                        testQuestionBtn.innerHTML = '<i class="bi bi-cpu me-2"></i>Daily Limit Reached';
                        rateLimitInfo.className = 'text-warning';
                    }
                }
            } else {
                console.error('Failed to load rate limit info:', data.error);
            }
        })
        .catch(error => {
            console.error('Error loading rate limits:', error);
            const rateLimitInfo = document.getElementById('rate-limit-info');
            if (rateLimitInfo) {
                rateLimitInfo.innerHTML = 'Unable to load limit information';
                rateLimitInfo.className = 'text-warning';
            }
        });
    }
    
    function testQuestionWithAI() {
        // Get current question ID - use currentQuestionId which gets updated after creation
        const questionId = currentQuestionId || {% if form.instance.pk %}{{ form.instance.pk }}{% else %}0{% endif %};

        // Get question title and text for validation
        const titleInput = document.querySelector('input[name="title"]');
        const textField = document.querySelector('textarea[name="text"]');

        // Basic validation
        if (!titleInput || !titleInput.value.trim()) {
            showAIError('Please enter a question title before testing.');
            return;
        }

        // Get text content from SimpleMDE if available, otherwise from textarea
        let textContent = '';
        if (textField && textField.simplemde) {
            textContent = textField.simplemde.value();
        } else if (textField) {
            textContent = textField.value;
        }

        if (!textContent.trim()) {
            showAIError('Please enter question content before testing.');
            return;
        }
        
        // Show loading state
        showAILoading();
        
        // For new questions, we need to save first, then test
        if (questionId === 0) {
            // Save question first, then test
            saveQuestionThenTest();
        } else {
            // For existing questions, save current state first, then test
            saveExistingQuestionThenTest(questionId);
        }
    }
    
    function saveExistingQuestionThenTest(questionId) {
        const form = document.querySelector('.question-form');
        // Sync SimpleMDE editors to textareas before collecting form data
        syncSimpleMDEEditors();
        const formData = new FormData(form);
        const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;
        
        // Use the ajax-save-draft endpoint for existing questions
        const saveUrl = `/questions/${questionId}/ajax-save-draft/`;
        
        fetch(saveUrl, {
            method: 'POST',
            body: formData,
            headers: {
                'X-CSRFToken': csrfToken,
                'X-Requested-With': 'XMLHttpRequest'
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success) {
                console.log('Question saved successfully before testing');
                // Question saved, now test it
                performAITest(questionId);
            } else {
                showAIError('Please fix form errors before testing: ' + (data.errors || 'Unknown error'));
                resetAITestButton();
            }
        })
        .catch(error => {
            console.error('Error saving question:', error);
            showAIError('Failed to save question before testing. Please try again.');
            resetAITestButton();
        });
    }
    
    function saveQuestionThenTest() {
        const form = document.querySelector('.question-form');
        // Sync SimpleMDE editors to textareas before collecting form data
        syncSimpleMDEEditors();
        const formData = new FormData(form);
        const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;
        
        fetch('{% url "questions:ajax_save_create" %}', {
            method: 'POST',
            body: formData,
            headers: {
                'X-CSRFToken': csrfToken,
                'X-Requested-With': 'XMLHttpRequest'
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success && data.question_id) {
                // Update current question ID to prevent duplicate creation
                currentQuestionId = data.question_id;
                console.log('Question saved with ID:', data.question_id);
                
                // Update form action URL to edit mode instead of create mode
                const form = document.querySelector('.question-form');
                if (form) {
                    const newAction = `/questions/${data.question_id}/edit/`;
                    form.action = newAction;
                    console.log('Updated form action to:', newAction);
                    
                    // Update submit button text to reflect edit mode
                    const submitBtn = form.querySelector('input[name="save"], button[name="save"]');
                    if (submitBtn && submitBtn.value === 'Save Question') {
                        submitBtn.value = 'Save and Exit';
                        console.log('Updated submit button text to edit mode');
                    }
                }
                
                // Question saved successfully, now test it
                performAITest(data.question_id);
            } else {
                showAIError('Please save the question successfully before testing. Fix any form errors and try again.');
                resetAITestButton();
            }
        })
        .catch(error => {
            console.error('Error saving question:', error);
            showAIError('Failed to save question before testing. Please try again.');
            resetAITestButton();
        });
    }
    
    let pollInterval = null;
    let pollAttempts = 0;
    const MAX_POLL_ATTEMPTS = 180;  // 15 minutes with 5-second intervals
    let currentTestAttemptId = null;  // Track current test for cancellation
    
    function performAITest(questionId) {
        const url = `/ai-testing/test/${questionId}/`;
        
        fetch(url, {
            method: 'POST',
            headers: {
                'Content-Type': 'application/json',
                'X-Requested-With': 'XMLHttpRequest',
                'X-CSRFToken': document.querySelector('[name=csrfmiddlewaretoken]').value
            },
            body: JSON.stringify({
                test_type: 'main'
            })
        })
        .then(response => {
            if (!response.ok && response.status !== 202) {
                return response.json().then(data => {
                    throw {status: response.status, data: data};
                });
            }
            return response.json();
        })
        .then(data => {
            if (data.success && data.test_attempt_id) {
                // Task queued successfully, start polling
                console.log('AI test queued with task ID:', data.task_id);
                updateLoadingMessage('AI test queued for processing...');
                pollForResults(data.test_attempt_id);
            } else {
                showAIError(data.error || 'Failed to queue AI test.');
                resetAITestButton();
            }
        })
        .catch(error => {
            console.error('AI test error:', error);

            // Log detailed debug information if available
            if (error.data && error.data.debug_info) {
                console.group('🔍 AI Test Debug Information');
                console.error('Error Type:', error.data.error_type || 'Unknown');
                console.error('Error Message:', error.data.error || 'No message');
                console.log('Debug Info:', error.data.debug_info);

                if (error.data.debug_info) {
                    Object.entries(error.data.debug_info).forEach(([key, value]) => {
                        console.log(`  ${key}:`, value);
                    });
                }

                if (error.data.help) {
                    console.info('ℹ️ Help:', error.data.help);
                }
                console.groupEnd();
            }

            if (error.status === 429) {
                // Rate limit error
                showAIError(error.data.error || 'Rate limit exceeded. Please try again later.');
            } else if (error.status === 404) {
                showAIError('Question not found.');
            } else if (error.status === 503 && error.data) {
                // Service initialization error - show detailed message
                let errorMsg = error.data.error || 'Service temporarily unavailable.';
                if (error.data.help) {
                    errorMsg += '\n\n' + error.data.help;
                }
                showAIError(errorMsg);
            } else {
                showAIError('Failed to start AI test. Please try again. Check browser console (F12) for details.');
            }
            resetAITestButton();
        });
    }
    
    function pollForResults(testAttemptId) {
        currentTestAttemptId = testAttemptId;  // Store for cancellation
        pollAttempts = 0;
        
        // Clear any existing poll interval
        if (pollInterval) {
            clearInterval(pollInterval);
        }
        
        // Poll every 5 seconds
        pollInterval = setInterval(() => {
            pollAttempts++;
            
            // Check if we've exceeded max attempts
            if (pollAttempts > MAX_POLL_ATTEMPTS) {
                clearInterval(pollInterval);
                showAIError('The AI test timed out while attempting to solve this problem. This can occur for particularly complex questions. Note that models in the actual benchmark evaluation will have significantly more time to work through challenging problems.');
                resetAITestButton();
                return;
            }
            
            // Update loading message with progress
            const elapsedSeconds = pollAttempts * 5;
            const minutes = Math.floor(elapsedSeconds / 60);
            const seconds = elapsedSeconds % 60;
            let timeMsg = seconds + ' seconds';
            if (minutes > 0) {
                timeMsg = `${minutes} minute${minutes > 1 ? 's' : ''} ${seconds} second${seconds !== 1 ? 's' : ''}`;
            }
            updateLoadingMessage(`AI is solving your question... (${timeMsg} elapsed)`);
            
            // Check status
            fetch(`/ai-testing/status/${testAttemptId}/`, {
                method: 'GET',
                headers: {
                    'X-Requested-With': 'XMLHttpRequest',
                }
            })
            .then(response => response.json())
            .then(data => {
                if (data.success) {
                    if (data.status === 'success') {
                        // Test completed successfully
                        clearInterval(pollInterval);
                        pollInterval = null;
                        showAIResponse(data);
                        loadRateLimitInfo();
                    } else if (data.status === 'error' || data.status === 'timeout' || data.status === 'rate_limited' || data.status === 'cancelled') {
                        // Test failed or cancelled
                        clearInterval(pollInterval);
                        pollInterval = null;
                        currentTestAttemptId = null;
                        showAIError(data.error || `Test ${data.status === 'cancelled' ? 'cancelled' : 'failed'} with status: ${data.status}`);
                        resetAITestButton();
                    }
                    // If status is 'pending' or 'processing', continue polling
                } else {
                    // Error checking status
                    console.error('Error checking test status:', data.error);
                }
            })
            .catch(error => {
                console.error('Error polling for results:', error);
                // Continue polling despite error
            });
        }, 5000);  // Poll every 5 seconds
    }
    
    function updateLoadingMessage(message) {
        const loadingDiv = document.getElementById('ai-loading');
        if (loadingDiv && loadingDiv.style.display === 'block') {
            const messageDiv = loadingDiv.querySelector('.fw-bold');
            if (messageDiv) {
                messageDiv.textContent = message;
            }
        }
    }
    
    function showAILoading() {
        // Clear and hide previous responses
        document.getElementById('ai-response-area').style.display = 'none';
        document.getElementById('ai-error').style.display = 'none';
        
        // Hide any previous AI test result from the template (when editing existing questions)
        const previousAISection = document.querySelector('.alert.alert-light.border-info');
        if (previousAISection) {
            previousAISection.style.display = 'none';
        }
        
        // Clear any existing response content
        const responseContent = document.getElementById('ai-response-content');
        if (responseContent) {
            responseContent.innerHTML = '';
        }
        
        // Show loading state
        document.getElementById('ai-loading').style.display = 'block';
        
        // Reset cancel button to its original state (in case it was left in "Cancelling..." state)
        const cancelBtn = document.getElementById('cancel-ai-test');
        if (cancelBtn) {
            cancelBtn.disabled = false;
            cancelBtn.innerHTML = '<i class="bi bi-x-circle me-1"></i>Cancel Test';
        }
        
        // Disable test button
        const testBtn = document.getElementById('test-question-btn');
        testBtn.disabled = true;
        testBtn.innerHTML = '<i class="bi bi-hourglass-split me-2"></i>AI Solving...';
    }
    
    function showAIResponse(data) {
        // Hide other states
        document.getElementById('ai-loading').style.display = 'none';
        document.getElementById('ai-error').style.display = 'none';
        
        // Populate response data
        const responseArea = document.getElementById('ai-response-area');
        const responseContent = document.getElementById('ai-response-content');
        const responseRawContent = document.getElementById('ai-response-raw-content');
        const responseMetadata = document.getElementById('response-metadata');
        const responseTime = document.getElementById('response-time');
        const responseCost = document.getElementById('response-cost');
        const remainingTests = document.getElementById('remaining-tests');
        
        // Store the raw response for toggle
        const rawResponse = data.raw_response || data.response;
        
        // Set both rendered and raw content
        responseContent.innerHTML = data.response;
        if (responseRawContent) {
            responseRawContent.textContent = rawResponse;
        }

        // Render math using MathJax (loaded in base.html)
        if (typeof MathJax !== 'undefined' && MathJax.typesetPromise) {
            MathJax.typesetPromise([responseContent]).catch(err => {
                console.error('MathJax rendering error:', err);
            });
        }
        
        // Add metadata with API info
        let modelText = data.token_usage ? 'GPT-5' : 'OpenAI';
        if (data.api_used === 'responses') {
            modelText += ' with web search and code interpreter';
        } else if (data.api_used === 'chat_completions') {
            modelText += ' (standard mode)';
        } else {
            // Fallback for backward compatibility
            modelText += ' with web search and code interpreter';
        }
        responseMetadata.textContent = `Model: ${modelText}`;
        responseTime.textContent = `${data.response_time_ms}ms`;
        responseCost.textContent = data.cost_estimate ? `$${data.cost_estimate.toFixed(4)}` : 'N/A';
        
        // Log AI test summary to console
        const tokens = data.token_usage || {};
        const tools = data.tool_usage || {};
        const toolCount = (tools.web_search_calls || 0) + (tools.code_interpreter_sessions || 0);
        
        console.log(`🤖 AI Test: ${data.api_used || 'chat'} API | ${tokens.total_tokens || 0} tokens (${tokens.cached_tokens || 0} cached) | ${toolCount} tools | $${data.cost_estimate?.toFixed(4) || 'N/A'}`);
        
        if (data.fallback_reason) {
            console.warn('⚠️ API Fallback:', data.fallback_reason);
        }
        
        if (data.remaining_limits) {
            remainingTests.textContent = `${data.remaining_limits.user_daily} solution attempts remaining today, ${data.remaining_limits.question_daily} for this question`;
        } else {
            remainingTests.textContent = 'Limits updated';
        }
        
        // Show response area
        responseArea.style.display = 'block';
        
        // Scroll to response
        responseArea.scrollIntoView({ behavior: 'smooth', block: 'center' });
        
        // Re-enable test button
        resetAITestButton();
    }
    
    function showAIError(errorMessage) {
        // Hide other states
        document.getElementById('ai-loading').style.display = 'none';
        document.getElementById('ai-response-area').style.display = 'none';
        
        // Show error
        const errorArea = document.getElementById('ai-error');
        const errorContent = document.getElementById('ai-error-content');
        
        errorContent.textContent = errorMessage;
        errorArea.style.display = 'block';
        
        // Scroll to error
        errorArea.scrollIntoView({ behavior: 'smooth', block: 'center' });
        
        // Re-enable test button
        resetAITestButton();
    }
    
    // Add event listener for cancel button (using delegation since button is created dynamically)
    document.addEventListener('click', function(e) {
        if (e.target && (e.target.id === 'cancel-ai-test' || e.target.closest('#cancel-ai-test'))) {
            e.preventDefault();
            cancelAITest();
        }
    });
    
    function cancelAITest() {
        console.log('Cancel button clicked, currentTestAttemptId:', currentTestAttemptId);
        
        if (!currentTestAttemptId) {
            console.error('No test to cancel');
            return;
        }
        
        // Disable cancel button
        const cancelBtn = document.getElementById('cancel-ai-test');
        if (cancelBtn) {
            cancelBtn.disabled = true;
            cancelBtn.innerHTML = '<i class="bi bi-hourglass-split me-1"></i>Cancelling...';
        }
        
        console.log('Sending cancel request for test attempt:', currentTestAttemptId);
        
        // Send cancel request
        fetch(`/ai-testing/cancel/${currentTestAttemptId}/`, {
            method: 'POST',
            headers: {
                'Content-Type': 'application/json',
                'X-Requested-With': 'XMLHttpRequest',
                'X-CSRFToken': document.querySelector('[name=csrfmiddlewaretoken]').value
            }
        })
        .then(response => {
            console.log('Cancel response status:', response.status);
            return response.json();
        })
        .then(data => {
            console.log('Cancel response data:', data);
            if (data.success) {
                // Stop polling
                if (pollInterval) {
                    clearInterval(pollInterval);
                    pollInterval = null;
                }
                currentTestAttemptId = null;
                
                // Show cancellation message
                showAIError('Test cancelled by user');
                resetAITestButton();
            } else {
                console.error('Failed to cancel test:', data.error);
                // Re-enable cancel button if cancellation failed
                if (cancelBtn) {
                    cancelBtn.disabled = false;
                    cancelBtn.innerHTML = '<i class="bi bi-x-circle me-1"></i>Cancel';
                }
            }
        })
        .catch(error => {
            console.error('Error cancelling test:', error);
            // Re-enable cancel button on error
            if (cancelBtn) {
                cancelBtn.disabled = false;
                cancelBtn.innerHTML = '<i class="bi bi-x-circle me-1"></i>Cancel';
            }
        });
    }
    
    function resetAITestButton() {
        const testBtn = document.getElementById('test-question-btn');
        testBtn.disabled = false;
        testBtn.innerHTML = '<i class="bi bi-cpu me-2"></i>Get AI Solution Attempt';
        
        // Clear any polling interval
        if (pollInterval) {
            clearInterval(pollInterval);
            pollInterval = null;
        }
        currentTestAttemptId = null;
    }
    
    // Clean up polling on page unload
    window.addEventListener('beforeunload', () => {
        if (pollInterval) {
            clearInterval(pollInterval);
        }
    });
    
});

// Toggle functions for AI response display (outside DOMContentLoaded for onclick handlers)
function showAIRenderedContent(button) {
    document.getElementById('ai-response-content').style.display = 'block';
    document.getElementById('ai-response-raw').style.display = 'none';
    
    // Update button states
    button.classList.add('active');
    button.nextElementSibling?.classList.remove('active');
}

function showAIRawContent(button) {
    document.getElementById('ai-response-content').style.display = 'none';
    document.getElementById('ai-response-raw').style.display = 'block';
    
    // Update button states
    button.classList.add('active');
    button.previousElementSibling?.classList.remove('active');
}
</script>
{% endblock %}
