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

{% block title %}Evaluation Details - Queue #{{ queue_item.id }}{% endblock %}

{% block content %}
<div class="container-fluid">
    <div class="row">
        <div class="col-12">
            <nav aria-label="breadcrumb">
                <ol class="breadcrumb">
                    <li class="breadcrumb-item"><a href="{% url 'model_evaluation:index' %}">Model Evaluations</a></li>
                    <li class="breadcrumb-item active">Evaluation #{{ queue_item.id }}</li>
                </ol>
            </nav>
            
            <div class="d-flex justify-content-between align-items-start mb-4">
                <h1>Evaluation Details</h1>
                {% if user.is_staff and can_reevaluate %}
                    {% if is_released %}
                        <!-- Special warning for released evaluations -->
                        <button type="button" class="btn btn-danger" 
                                data-bs-toggle="modal" data-bs-target="#releasedRerunModal">
                            <i class="fas fa-exclamation-triangle"></i> Re-run Released Evaluation
                        </button>
                    {% elif reevaluation_type == 'retry' %}
                        <!-- Simple re-run for failed evaluations -->
                        <form method="post" action="{% url 'model_evaluation:create_reevaluation' queue_item.id %}" 
                              class="d-inline" onsubmit="return confirm('Are you sure you want to re-run this failed evaluation?')">
                            {% csrf_token %}
                            <button type="submit" class="btn btn-warning">
                                <i class="fas fa-redo"></i> Re-run Evaluation
                            </button>
                        </form>
                    {% elif reevaluation_type == 'restart' %}
                        <!-- Simple re-run for cancelled evaluations -->
                        <form method="post" action="{% url 'model_evaluation:create_reevaluation' queue_item.id %}" 
                              class="d-inline" onsubmit="return confirm('Are you sure you want to re-run this cancelled evaluation?')">
                            {% csrf_token %}
                            <button type="submit" class="btn btn-secondary">
                                <i class="fas fa-play"></i> Re-run Evaluation
                            </button>
                        </form>
                    {% else %}
                        <!-- Re-run button with modal for completed evaluations -->
                        <button type="button" class="btn btn-{% if has_grading %}danger{% else %}primary{% endif %}" 
                                data-bs-toggle="modal" data-bs-target="#rerunModal">
                            <i class="fas fa-play"></i> Re-run Evaluation
                            {% if has_grading %}<i class="fas fa-exclamation-triangle ms-1"></i>{% endif %}
                        </button>
                    {% endif %}
                {% endif %}
            </div>
            
            {% if is_released %}
            <div class="alert alert-success mb-4">
                <i class="bi bi-check-circle-fill me-2"></i>
                <strong>Released for Grading:</strong> This evaluation has been released to the question author for grading.
            </div>
            {% endif %}
            
            <!-- Evaluation Overview -->
            <div class="card mb-4">
                <div class="card-header">
                    <h3 class="mb-0">
                        <span class="badge 
                            {% if queue_item.status == 'pending' %}bg-warning text-dark
                            {% elif queue_item.status == 'running' %}bg-primary text-white
                            {% elif queue_item.status == 'completed' %}bg-success text-white
                            {% elif queue_item.status == 'failed' %}bg-danger text-white
                            {% else %}bg-secondary text-white{% endif %}
                            me-2">
                            {{ queue_item.status|title }}
                        </span>
                        Queue #{{ queue_item.id }}
                    </h3>
                </div>
                <div class="card-body">
                    <div class="row">
                        <div class="col-md-6">
                            <h5>Model Information</h5>
                            <p><strong>Model:</strong> {{ queue_item.model.model_name }}</p>
                            <p><strong>Company:</strong> {{ queue_item.model.company.company_name|title }}</p>
                            <p><strong>Tier:</strong> {{ queue_item.model.tier.tier_number }} - {{ queue_item.model.tier.tier_name }}</p>
                            <p><strong>Attempt Number:</strong> {{ queue_item.attempt_number }}</p>
                        </div>
                        <div class="col-md-6">
                            <h5>Timing Information</h5>
                            <p><strong>Submitted:</strong> {{ queue_item.submitted_at|date:"M d, Y H:i:s" }}</p>
                            {% if queue_item.started_at %}
                                <p><strong>Started:</strong> {{ queue_item.started_at|date:"M d, Y H:i:s" }}</p>
                            {% endif %}
                            {% if queue_item.completed_at %}
                                <p><strong>Completed:</strong> {{ queue_item.completed_at|date:"M d, Y H:i:s" }}</p>
                            {% endif %}
                        </div>
                    </div>
                </div>
            </div>
            
            <!-- Question Information -->
            <div class="card mb-4">
                <div class="card-header">
                    <h3 class="mb-0">Question</h3>
                </div>
                <div class="card-body">
                    <h4>
                        {{ queue_item.question.title }}
                        <a href="{% url 'questions:detail' queue_item.question.id %}" 
                           class="text-decoration-underline ms-2 text-muted"
                           style="text-decoration-color: inherit;">
                            <small>(Q{{ queue_item.question.id }})</small>
                        </a>
                    </h4>
                    {% if queue_item.question.text %}
                        <div class="mt-3">
                            <h5>Question Text</h5>
                            <div class="border rounded p-3 bg-light">
                                {{ queue_item.question.text|markdown_latex }}
                            </div>
                        </div>
                    {% endif %}
                </div>
            </div>
            
            <!-- Error Information (for failed evaluations) -->
            {% if queue_item.status == 'failed' and queue_item.error_message %}
                <div class="card mb-4">
                    <div class="card-header bg-danger text-white">
                        <h3 class="mb-0">Error Information</h3>
                    </div>
                    <div class="card-body">
                        <pre class="text-danger">{{ queue_item.error_message }}</pre>
                    </div>
                </div>
            {% endif %}
            
            <!-- Model Answer (for completed evaluations) -->
            {% if model_answer %}
                <div class="card mb-4">
                    <div class="card-header">
                        <h3 class="mb-0">Model Response</h3>
                    </div>
                    <div class="card-body">
                        {% include 'includes/model_answer_display.html' with answer_text=model_answer.answer show_toggle=True %}
                        
                        {% if model_answer.terminal_log_hash %}
                            <div class="mt-3">
                                <small class="text-muted">
                                    <strong>Terminal Log Hash:</strong> {{ model_answer.terminal_log_hash }}
                                    {% if conversation_log %}
                                        <button class="btn btn-sm btn-outline-secondary ms-2" 
                                                onclick="toggleConversationLog()" 
                                                id="logToggleBtn">
                                            <i class="bi bi-chat-text me-1"></i>Show Full Conversation Log
                                        </button>
                                    {% endif %}
                                </small>
                                
                                {% if conversation_log %}
                                    <!-- Collapsible Conversation Log Section -->
                                    <div id="conversationLogSection" class="mt-3" style="display: none;">
                                        <div class="card border-secondary">
                                            <div class="card-header bg-light d-flex justify-content-between align-items-center">
                                                <h6 class="mb-0">
                                                    <i class="bi bi-terminal me-2"></i>Full Conversation Log
                                                </h6>
                                                <div class="btn-group btn-group-sm" role="group">
                                                    <button class="btn btn-outline-primary log-action-btn" 
                                                            onclick="downloadConversationLog()"
                                                            title="Download Log as Text File">
                                                        <i class="bi bi-download"></i>
                                                    </button>
                                                    <button class="btn btn-outline-primary log-action-btn" 
                                                            onclick="searchInLog()"
                                                            title="Search Log">
                                                        <i class="bi bi-search"></i>
                                                    </button>
                                                </div>
                                            </div>
                                            <div class="card-body p-0">
                                                <div id="logSearchBox" class="p-2 border-bottom bg-light" style="display: none;">
                                                    <div class="input-group input-group-sm">
                                                        <input type="text" 
                                                               class="form-control" 
                                                               id="logSearchInput"
                                                               placeholder="Search conversation log..."
                                                               onkeyup="performLogSearch(event)">
                                                        <button class="btn btn-outline-secondary" 
                                                                onclick="clearLogSearch()">
                                                            <i class="bi bi-x"></i>
                                                        </button>
                                                    </div>
                                                </div>
                                                <pre id="conversationLogContent" 
                                                     class="p-3 mb-0 bg-dark text-white conversation-log-pre" 
                                                     style="max-height: 600px; overflow-y: auto; font-family: 'Courier New', monospace; font-size: 0.85em; line-height: 1.4; white-space: pre-wrap; word-wrap: break-word;">{{ conversation_log }}</pre>
                                            </div>
                                        </div>
                                    </div>
                                {% endif %}
                            </div>
                        {% endif %}
                    </div>
                </div>
                
                <!-- Subquestion Answers -->
                {% if subquestion_answers %}
                    <div class="card mb-4">
                        <div class="card-header">
                            <h3 class="mb-0">Subquestion Answers</h3>
                        </div>
                        <div class="card-body">
                            {% if user.is_staff %}
                                <!-- Hidden form for CSRF token -->
                                <form style="display: none;">
                                    {% csrf_token %}
                                </form>
                            {% endif %}
                            <div class="table-responsive">
                                <table class="table table-sm">
                                    <thead>
                                        <tr>
                                            <th style="width: 5%">Order</th>
                                            <th style="width: 30%">Question</th>
                                            <th style="width: 15%">Correct Answer</th>
                                            <th style="width: 15%">Model Answer</th>
                                            <th style="width: 15%">Status</th>
                                            {% if user.is_staff %}
                                                <th style="width: 20%">Admin Override</th>
                                            {% endif %}
                                        </tr>
                                    </thead>
                                    <tbody>
                                        {% for sub_answer in subquestion_answers %}
                                            <tr data-subquestion-answer-id="{{ sub_answer.id }}">
                                                <td><strong>{{ sub_answer.subquestion.subquestion_order }}</strong></td>
                                                <td>{{ sub_answer.subquestion.text }}</td>
                                                <td>
                                                    <code class="text-primary">{{ sub_answer.subquestion.answer }}</code>
                                                </td>
                                                <td>
                                                    {% if sub_answer.answer %}
                                                        <code>{{ sub_answer.answer }}</code>
                                                    {% else %}
                                                        <span class="text-muted">No answer</span>
                                                    {% endif %}
                                                </td>
                                                <td class="status-cell">
                                                    {% if sub_answer.admin_override is not None %}
                                                        {% if sub_answer.admin_override == 1 %}
                                                            <span class="badge bg-success">Correct (Admin Override)</span>
                                                        {% else %}
                                                            <span class="badge bg-danger">Incorrect (Admin Override)</span>
                                                        {% endif %}
                                                    {% elif sub_answer.is_correct is not None %}
                                                        {% if sub_answer.is_correct == 1 %}
                                                            <span class="badge bg-success">Correct</span>
                                                        {% else %}
                                                            <span class="badge bg-danger">Incorrect</span>
                                                        {% endif %}
                                                    {% else %}
                                                        <span class="badge bg-secondary">Not graded</span>
                                                    {% endif %}
                                                </td>
                                                {% if user.is_staff %}
                                                    <td>
                                                        <select class="form-select form-select-sm admin-override-select" 
                                                                data-subquestion-answer-id="{{ sub_answer.id }}">
                                                            <option value="null" {% if sub_answer.admin_override is None %}selected{% endif %}>
                                                                Use automatic evaluation
                                                            </option>
                                                            <option value="1" {% if sub_answer.admin_override == 1 %}selected{% endif %}>
                                                                Override: Correct
                                                            </option>
                                                            <option value="0" {% if sub_answer.admin_override == 0 %}selected{% endif %}>
                                                                Override: Incorrect
                                                            </option>
                                                        </select>
                                                    </td>
                                                {% endif %}
                                            </tr>
                                        {% endfor %}
                                    </tbody>
                                </table>
                            </div>
                            {% if user.is_staff %}
                                <div class="mt-2">
                                    <small class="text-muted">
                                        <i class="bi bi-info-circle"></i> 
                                        Admin overrides take precedence over automatic evaluation results.
                                        Use this feature when automatic parsing fails to correctly evaluate an answer.
                                    </small>
                                </div>
                            {% endif %}
                        </div>
                    </div>
                {% endif %}
            {% endif %}
            
            <!-- Navigation -->
            <div class="mt-4">
                <a href="{% url 'model_evaluation:index' %}" class="btn btn-secondary">
                    ← Back to Model Evaluations
                </a>
            </div>
        </div>
    </div>
</div>

<!-- Released Evaluation Re-run Warning Modal -->
{% if user.is_staff and is_released %}
<div class="modal fade" id="releasedRerunModal" tabindex="-1" aria-labelledby="releasedRerunModalLabel" aria-hidden="true">
    <div class="modal-dialog modal-lg">
        <div class="modal-content">
            <div class="modal-header bg-danger text-white">
                <h5 class="modal-title" id="releasedRerunModalLabel">
                    <i class="fas fa-exclamation-triangle me-2"></i>
                    Warning: Re-running Released Evaluation
                </h5>
                <button type="button" class="btn-close btn-close-white" data-bs-dismiss="modal" aria-label="Close"></button>
            </div>
            <div class="modal-body">
                <div class="alert alert-danger">
                    <h5 class="alert-heading">⚠️ Critical Action</h5>
                    <p><strong>This evaluation has been released for grading to the question author.</strong></p>
                </div>
                
                <h6>Consequences of re-running:</h6>
                <ul>
                    <li>The evaluation will be <strong>removed from grading release</strong></li>
                    <li>The question author will <strong>lose access</strong> to this evaluation for grading</li>
                    <li>Any grading work in progress may be <strong>interrupted</strong></li>
                    <li>After re-running completes, you will need to <strong>manually re-release</strong> for grading</li>
                    <li>The new evaluation may produce <strong>different results</strong></li>
                </ul>
                
                <div class="bg-light p-3 rounded mt-3">
                    <p class="mb-1"><strong>Model:</strong> {{ queue_item.model.model_name }}</p>
                    <p class="mb-1"><strong>Question:</strong> {{ queue_item.question.title }}</p>
                    <p class="mb-0"><strong>Attempt:</strong> #{{ queue_item.attempt_number }}</p>
                </div>
                
                <div class="mt-3">
                    <strong>Are you absolutely sure you want to proceed?</strong>
                </div>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Cancel</button>
                <form method="post" action="{% url 'model_evaluation:create_reevaluation' queue_item.id %}" class="d-inline">
                    {% csrf_token %}
                    <input type="hidden" name="confirm_release_override" value="true">
                    <button type="submit" class="btn btn-danger">
                        <i class="fas fa-exclamation-triangle me-1"></i>
                        Yes, Remove from Grading and Re-run
                    </button>
                </form>
            </div>
        </div>
    </div>
</div>
{% endif %}

<!-- Re-run Confirmation Modal -->
{% if user.is_staff and reevaluation_type == 'rerun' %}
<div class="modal fade" id="rerunModal" tabindex="-1" aria-labelledby="rerunModalLabel" aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <h5 class="modal-title" id="rerunModalLabel">
                    {% if has_grading %}
                        <i class="fas fa-exclamation-triangle text-warning me-2"></i>
                        Confirm Re-run with Existing Grading
                    {% else %}
                        Confirm Re-run Evaluation
                    {% endif %}
                </h5>
                <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
            </div>
            <div class="modal-body">
                {% if has_grading %}
                    <div class="alert alert-warning">
                        <strong>Warning:</strong> This evaluation already has grading records. Re-running will generate a new model answer, which may invalidate the existing grading.
                    </div>
                    <p><strong>Model:</strong> {{ queue_item.model.model_name }}</p>
                    <p><strong>Question:</strong> {{ queue_item.question.title }}</p>
                    <p><strong>Attempt:</strong> #{{ queue_item.attempt_number }}</p>
                    <p>Are you sure you want to proceed? The existing grading may need to be re-done.</p>
                {% else %}
                    <p>This will re-run the evaluation and generate a new model answer.</p>
                    <p><strong>Model:</strong> {{ queue_item.model.model_name }}</p>
                    <p><strong>Question:</strong> {{ queue_item.question.title }}</p>
                    <p><strong>Attempt:</strong> #{{ queue_item.attempt_number }}</p>
                    <p>Are you sure you want to proceed?</p>
                {% endif %}
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Cancel</button>
                <form method="post" action="{% url 'model_evaluation:create_reevaluation' queue_item.id %}" class="d-inline">
                    {% csrf_token %}
                    <button type="submit" class="btn btn-{% if has_grading %}danger{% else %}primary{% endif %}">
                        {% if has_grading %}
                            <i class="fas fa-exclamation-triangle me-1"></i>
                            Proceed with Re-run
                        {% else %}
                            <i class="fas fa-play me-1"></i>
                            Re-run Evaluation
                        {% endif %}
                    </button>
                </form>
            </div>
        </div>
    </div>
</div>
{% endif %}

{% endblock %}

{% block extra_css %}
<style>
    /* Styling for model answer content with rendered markdown */
    .model-answer-content {
        line-height: 1.6;
    }
    
    
    .model-answer-content p:last-child {
        margin-bottom: 0;
    }
    
    /* Ensure proper spacing for mathematical display equations */
    .model-answer-content .MathJax_Display {
        margin: 1em 0;
    }
    
    /* Code blocks within answers */
    .model-answer-content pre {
        background-color: #f8f9fa;
        border: 1px solid #dee2e6;
        border-radius: 0.25rem;
        padding: 0.5rem;
        margin: 0.5rem 0;
    }
    
    /* Inline code */
    .model-answer-content code {
        background-color: #f8f9fa;
        padding: 0.125rem 0.25rem;
        border-radius: 0.25rem;
        font-size: 0.875em;
    }
    
    /* Lists within answers */
    .model-answer-content ul, .model-answer-content ol {
        margin-bottom: 1rem;
    }
    
    .model-answer-content li {
        margin-bottom: 0.25rem;
    }
    
    /* Styling for raw content view */
    #raw-content pre {
        font-family: 'Courier New', Courier, monospace;
        font-size: 0.9rem;
        color: #333;
        background-color: transparent;
        border: none;
        padding: 0;
    }
    
    /* Toggle button styling */
    .btn-group-sm .btn {
        padding: 0.25rem 0.75rem;
        font-size: 0.875rem;
    }
    
    .btn-outline-secondary.active {
        background-color: #6c757d;
        border-color: #6c757d;
        color: white;
    }
    
    .btn-outline-secondary:not(.active):hover {
        background-color: #f8f9fa;
    }
    
    /* Conversation log styling */
    .log-action-btn {
        border-color: #0d6efd !important;
        color: #0d6efd !important;
    }
    
    .log-action-btn:hover {
        background-color: #0d6efd !important;
        color: white !important;
        border-color: #0d6efd !important;
    }
    
    .log-action-btn.btn-success {
        background-color: #198754 !important;
        border-color: #198754 !important;
        color: white !important;
    }
    
    .conversation-log-pre {
        border-radius: 0 !important;
        margin: 0 !important;
    }
    
    .conversation-log-pre mark {
        background-color: #fff3cd !important;
        color: #664d03 !important;
        padding: 0.1em 0.2em;
        border-radius: 0.25rem;
    }
    
    #logToggleBtn:hover {
        background-color: #6c757d !important;
        color: white !important;
        border-color: #6c757d !important;
    }
</style>
{% endblock %}

{% block extra_js %}
<script>
    // Ensure MathJax processes the math content after page load with robust error handling
    document.addEventListener('DOMContentLoaded', function() {
        if (typeof MathJax !== 'undefined') {
            console.log('MathJax is loaded, processing math content...');

            // First, validate math elements for common issues
            var mathElements = document.querySelectorAll('script[type="math/tex"], script[type="math/tex; mode=display"]');
            console.log('Found ' + mathElements.length + ' math elements to process');

            // Check for problematic patterns
            mathElements.forEach(function(element, index) {
                var content = element.textContent;

                // Check for unmatched braces
                var openBraces = (content.match(/\{/g) || []).length;
                var closeBraces = (content.match(/\}/g) || []).length;
                if (openBraces !== closeBraces) {
                    console.warn('Math element ' + index + ' has unmatched braces:', content.substring(0, 100));
                }

                // Check for unmatched brackets
                var openBrackets = (content.match(/\[/g) || []).length;
                var closeBrackets = (content.match(/\]/g) || []).length;
                if (openBrackets !== closeBrackets) {
                    console.warn('Math element ' + index + ' has unmatched brackets:', content.substring(0, 100));
                }

                // Check for empty content
                if (content.trim() === '') {
                    console.warn('Math element ' + index + ' is empty');
                }
            });

            // Process all math content on the page with error handling
            MathJax.typesetPromise().then(function() {
                console.log('MathJax processing completed successfully');
            }).catch(function(err) {
                console.error('MathJax processing error:', err);
                console.error('Error details:', {
                    message: err.message,
                    stack: err.stack,
                    name: err.name
                });

                // Show user-friendly error message
                var alertDiv = document.createElement('div');
                alertDiv.className = 'alert alert-warning alert-dismissible fade show m-3';
                alertDiv.innerHTML = `
                    <strong>LaTeX Rendering Warning:</strong> Some mathematical expressions could not be rendered properly.
                    This may be due to malformed LaTeX in the model's output. You can view the raw content to see the original text.
                    <button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>
                `;

                // Insert alert at the top of the model answer section
                var modelAnswerCard = document.querySelector('.card-body');
                if (modelAnswerCard) {
                    modelAnswerCard.insertBefore(alertDiv, modelAnswerCard.firstChild);
                }
            });
        } else {
            console.error('MathJax is not loaded!');
        }
    });
    
    // Toggle view functionality is now handled by the included template
    
    // Conversation Log Functions
    function toggleConversationLog() {
        const section = document.getElementById('conversationLogSection');
        const btn = document.getElementById('logToggleBtn');
        
        if (section.style.display === 'none') {
            section.style.display = 'block';
            btn.innerHTML = '<i class="bi bi-chat-text-fill me-1"></i>Hide Conversation Log';
            btn.classList.remove('btn-outline-secondary');
            btn.classList.add('btn-secondary');
        } else {
            section.style.display = 'none';
            btn.innerHTML = '<i class="bi bi-chat-text me-1"></i>Show Full Conversation Log';
            btn.classList.remove('btn-secondary');
            btn.classList.add('btn-outline-secondary');
            // Also hide search if open
            const searchBox = document.getElementById('logSearchBox');
            if (searchBox) searchBox.style.display = 'none';
        }
    }


    function downloadConversationLog() {
        const logContent = document.getElementById('conversationLogContent');
        const text = logContent.textContent;
        
        // Create blob and download
        const blob = new Blob([text], { type: 'text/plain' });
        const url = window.URL.createObjectURL(blob);
        const a = document.createElement('a');
        a.href = url;
        a.download = 'conversation_log_{{ model_answer.terminal_log_hash|default:"unknown" }}.txt';
        document.body.appendChild(a);
        a.click();
        document.body.removeChild(a);
        window.URL.revokeObjectURL(url);
        
        // Show temporary success message
        const btn = event.target.closest('button');
        const originalHTML = btn.innerHTML;
        btn.innerHTML = '<i class="bi bi-check"></i>';
        btn.classList.add('btn-success');
        btn.classList.remove('btn-outline-primary');
        btn.classList.remove('log-action-btn');
        
        setTimeout(() => {
            btn.innerHTML = originalHTML;
            btn.classList.remove('btn-success');
            btn.classList.add('btn-outline-primary');
            btn.classList.add('log-action-btn');
        }, 2000);
    }

    function searchInLog() {
        const searchBox = document.getElementById('logSearchBox');
        const searchInput = document.getElementById('logSearchInput');
        
        if (searchBox.style.display === 'none') {
            searchBox.style.display = 'block';
            searchInput.focus();
        } else {
            clearLogSearch();
        }
    }

    function performLogSearch(event) {
        const searchTerm = event.target.value.toLowerCase();
        const logContent = document.getElementById('conversationLogContent');
        const originalText = logContent.dataset.originalText || logContent.textContent;
        
        // Store original text if not already stored
        if (!logContent.dataset.originalText) {
            logContent.dataset.originalText = originalText;
        }
        
        if (searchTerm === '') {
            logContent.innerHTML = originalText;
            return;
        }
        
        // Simple text highlighting (HTML escape first)
        const escapedText = originalText.replace(/</g, '&lt;').replace(/>/g, '&gt;');
        const highlightedText = escapedText.replace(
            new RegExp(`(${searchTerm.replace(/[.*+?^${}()|[\]\\]/g, '\\$&')})`, 'gi'),
            '<mark style="background-color: yellow; color: black;">$1</mark>'
        );
        
        logContent.innerHTML = highlightedText;
        
        // Scroll to first match
        const firstMatch = logContent.querySelector('mark');
        if (firstMatch) {
            firstMatch.scrollIntoView({ behavior: 'smooth', block: 'center' });
        }
    }

    function clearLogSearch() {
        const searchBox = document.getElementById('logSearchBox');
        const searchInput = document.getElementById('logSearchInput');
        const logContent = document.getElementById('conversationLogContent');
        
        searchBox.style.display = 'none';
        searchInput.value = '';
        
        // Restore original text
        if (logContent.dataset.originalText) {
            logContent.textContent = logContent.dataset.originalText;
        }
    }
    
    // Admin Override Functionality
    {% if user.is_staff %}
    document.addEventListener('DOMContentLoaded', function() {
        // Handle admin override dropdown changes
        const overrideSelects = document.querySelectorAll('.admin-override-select');
        
        overrideSelects.forEach(function(select) {
            select.addEventListener('change', function(e) {
                const subquestionAnswerId = e.target.dataset.subquestionAnswerId;
                const overrideValue = e.target.value;
                const row = e.target.closest('tr');
                const statusCell = row.querySelector('.status-cell');
                
                // Show loading state
                const originalHTML = statusCell.innerHTML;
                statusCell.innerHTML = '<span class="spinner-border spinner-border-sm" role="status"></span> Updating...';
                
                // Get CSRF token
                const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;
                
                // Send AJAX request to update the override
                fetch(`/model-evaluation/subquestion-override/${subquestionAnswerId}/`, {
                    method: 'POST',
                    headers: {
                        'Content-Type': 'application/json',
                        'X-CSRFToken': csrfToken
                    },
                    body: JSON.stringify({
                        override_value: overrideValue
                    })
                })
                .then(response => response.json())
                .then(data => {
                    if (data.success) {
                        // Update the status cell with the new status
                        let badgeClass = 'bg-secondary';
                        let badgeText = 'Not graded';
                        
                        if (data.effective_correctness === 1) {
                            badgeClass = 'bg-success';
                        } else if (data.effective_correctness === 0) {
                            badgeClass = 'bg-danger';
                        }
                        
                        statusCell.innerHTML = `<span class="badge ${badgeClass}">${data.new_status}</span>`;
                        
                        // Show success feedback
                        const successFeedback = document.createElement('div');
                        successFeedback.className = 'alert alert-success alert-dismissible fade show position-fixed top-0 start-50 translate-middle-x mt-3';
                        successFeedback.style.zIndex = '9999';
                        successFeedback.innerHTML = `
                            <i class="bi bi-check-circle"></i> Override updated successfully
                            <button type="button" class="btn-close" data-bs-dismiss="alert"></button>
                        `;
                        document.body.appendChild(successFeedback);
                        
                        // Auto-dismiss after 3 seconds
                        setTimeout(() => {
                            successFeedback.remove();
                        }, 3000);
                    } else {
                        // Show error and restore original state
                        statusCell.innerHTML = originalHTML;
                        
                        const errorFeedback = document.createElement('div');
                        errorFeedback.className = 'alert alert-danger alert-dismissible fade show position-fixed top-0 start-50 translate-middle-x mt-3';
                        errorFeedback.style.zIndex = '9999';
                        errorFeedback.innerHTML = `
                            <i class="bi bi-exclamation-triangle"></i> Error: ${data.error}
                            <button type="button" class="btn-close" data-bs-dismiss="alert"></button>
                        `;
                        document.body.appendChild(errorFeedback);
                        
                        // Reset the dropdown to its original value
                        // We need to get the original value from the data attribute
                        const originalValue = row.dataset.originalOverride || 'null';
                        e.target.value = originalValue;
                    }
                })
                .catch(error => {
                    // Show error and restore original state
                    statusCell.innerHTML = originalHTML;
                    console.error('Error updating override:', error);
                    
                    const errorFeedback = document.createElement('div');
                    errorFeedback.className = 'alert alert-danger alert-dismissible fade show position-fixed top-0 start-50 translate-middle-x mt-3';
                    errorFeedback.style.zIndex = '9999';
                    errorFeedback.innerHTML = `
                        <i class="bi bi-exclamation-triangle"></i> Network error occurred
                        <button type="button" class="btn-close" data-bs-dismiss="alert"></button>
                    `;
                    document.body.appendChild(errorFeedback);
                });
            });
            
            // Store the original value for potential reset
            const row = select.closest('tr');
            row.dataset.originalOverride = select.value;
        });
    });
    {% endif %}
</script>
{% endblock %}