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

{% block title %}Subquestion Parsing Check{% 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 'home' %}">Home</a></li>
                    <li class="breadcrumb-item active">Subquestion Parsing Check</li>
                </ol>
            </nav>

            <div class="d-flex justify-content-between align-items-center mb-4">
                <h1>Subquestion Parsing Check</h1>
            </div>

            <div class="alert alert-info">
                <i class="bi bi-info-circle me-2"></i>
                <strong>Purpose:</strong> Review and verify automatic parsing of model answers to subquestions.
                Once verified, answers are flagged as human-checked and won't appear again when "Hide answers with admin override" is enabled.
            </div>

            <!-- Filters -->
            <div class="card mb-4">
                <div class="card-header">
                    <h5 class="mb-0">Filters</h5>
                </div>
                <div class="card-body">
                    <form method="get" id="filterForm" class="row g-3">
                        <div class="col-md-4">
                            <label for="modelFilter" class="form-label">Filter by Model</label>
                            <select class="form-select" id="modelFilter" name="model" onchange="document.getElementById('filterForm').submit()">
                                <option value="">All Models</option>
                                {% for model in all_models %}
                                    <option value="{{ model.id }}" {% if selected_model == model.id|stringformat:"s" %}selected{% endif %}>
                                        Tier {{ model.tier.tier_number }}: {{ model.display_name|default:model.model_name }}
                                    </option>
                                {% endfor %}
                            </select>
                        </div>
                        <div class="col-md-8">
                            <label class="form-label d-block">&nbsp;</label>
                            <div class="form-check form-switch mb-2">
                                <input class="form-check-input" type="checkbox" id="hideOverridden" name="hide_overridden"
                                       value="true" {% if hide_overridden %}checked{% endif %}
                                       onchange="document.getElementById('filterForm').submit()">
                                <label class="form-check-label" for="hideOverridden">
                                    <strong>Hide answers with admin override</strong>
                                    <small class="text-muted">(Only show unverified answers)</small>
                                </label>
                            </div>
                            <div class="form-check form-switch">
                                <input class="form-check-input" type="checkbox" id="showMismatches" name="show_mismatches"
                                       value="true" {% if show_mismatches %}checked{% endif %}
                                       onchange="document.getElementById('filterForm').submit()">
                                <label class="form-check-label" for="showMismatches">
                                    <strong>Show only evaluation mismatches</strong>
                                    <small class="text-muted">(Where fresh automated evaluation differs from stored value)</small>
                                </label>
                            </div>
                        </div>
                    </form>
                </div>
            </div>

            <!-- Questions -->
            {% if questions_data %}
                {% for question_data in questions_data %}
                    <div class="card mb-4 question-card" id="question-{{ question_data.question.id }}">
                        <div class="card-header bg-primary text-white">
                            <h4 class="mb-0">
                                Question {{ question_data.question.id }}: {{ question_data.question.title }}
                            </h4>
                        </div>
                        <div class="card-body">
                            <!-- Question text -->
                            {% if question_data.question.text %}
                                <div class="mb-3 p-3 bg-light border rounded">
                                    <h6>Question Text:</h6>
                                    {{ question_data.question.text|markdown_latex }}
                                </div>
                            {% endif %}

                            <!-- Subquestions table -->
                            {% for subq_data in question_data.subquestions %}
                                {% if subq_data.model_answers %}
                                    <div class="subquestion-section mb-4">
                                        <h5 class="text-primary">
                                            Subquestion {{ subq_data.subquestion.subquestion_order }}
                                        </h5>

                                        <div class="mb-2">
                                            <strong>Question:</strong> {{ subq_data.subquestion.text }}
                                        </div>
                                        <div class="mb-3">
                                            <strong>Correct Answer:</strong>
                                            <code class="text-success">{{ subq_data.subquestion.answer }}</code>
                                        </div>

                                        <!-- Model answers table -->
                                        <div class="table-responsive">
                                            <table class="table table-sm table-bordered">
                                                <thead class="table-light">
                                                    <tr>
                                                        <th style="width: 13%">Model</th>
                                                        <th style="width: 6%">Tier</th>
                                                        <th style="width: 6%">Attempt</th>
                                                        <th style="width: 14%">Model Answer</th>
                                                        <th style="width: 11%">Stored Status</th>
                                                        <th style="width: 11%">Fresh Eval</th>
                                                        <th style="width: 19%">Admin Override</th>
                                                    </tr>
                                                </thead>
                                                <tbody>
                                                    {% for model_answer in subq_data.model_answers %}
                                                        <tr data-subquestion-answer-id="{{ model_answer.id }}" class="{% if model_answer.has_mismatch %}table-warning{% endif %}">
                                                            <td>{{ model_answer.model.display_name|default:model_answer.model.model_name }}</td>
                                                            <td>T{{ model_answer.model.tier.tier_number }}</td>
                                                            <td>{{ model_answer.attempt.attempt_number }}</td>
                                                            <td>
                                                                {% if model_answer.answer %}
                                                                    <code>{{ model_answer.answer }}</code>
                                                                {% else %}
                                                                    <span class="text-muted">No answer</span>
                                                                {% endif %}
                                                            </td>
                                                            <td class="status-cell">
                                                                {% if model_answer.admin_override is not None %}
                                                                    {% if model_answer.admin_override == 1 %}
                                                                        <span class="badge bg-success">Correct (Override)</span>
                                                                    {% else %}
                                                                        <span class="badge bg-danger">Incorrect (Override)</span>
                                                                    {% endif %}
                                                                {% elif model_answer.is_correct is not None %}
                                                                    {% if model_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>
                                                            <td class="fresh-eval-cell">
                                                                {% if model_answer.fresh_is_correct == 1 %}
                                                                    <span class="badge bg-success">Correct</span>
                                                                {% else %}
                                                                    <span class="badge bg-danger">Incorrect</span>
                                                                {% endif %}
                                                                {% if model_answer.has_mismatch %}
                                                                    <i class="bi bi-exclamation-triangle text-warning ms-1" title="Mismatch between stored and fresh evaluation"></i>
                                                                {% endif %}
                                                            </td>
                                                            <td>
                                                                <select class="form-select form-select-sm admin-override-select"
                                                                        data-subquestion-answer-id="{{ model_answer.id }}">
                                                                    <option value="null" {% if model_answer.admin_override is None %}selected{% endif %}>
                                                                        Use automatic evaluation
                                                                    </option>
                                                                    <option value="1" {% if model_answer.admin_override == 1 %}selected{% endif %}>
                                                                        Override: Correct
                                                                    </option>
                                                                    <option value="0" {% if model_answer.admin_override == 0 %}selected{% endif %}>
                                                                        Override: Incorrect
                                                                    </option>
                                                                </select>
                                                            </td>
                                                        </tr>
                                                    {% endfor %}
                                                </tbody>
                                            </table>
                                        </div>
                                    </div>
                                    <hr>
                                {% endif %}
                            {% endfor %}

                            <!-- Action buttons -->
                            <div class="mt-3">
                                <button class="btn btn-primary verify-question-btn"
                                        data-question-id="{{ question_data.question.id }}"
                                        onclick="markQuestionVerified({{ question_data.question.id }})">
                                    <i class="bi bi-check-circle me-2"></i>
                                    Mark all subquestion answers above as verified
                                </button>
                                <small class="text-muted ms-3">
                                    This will convert all "Use automatic evaluation" entries to admin overrides matching their current values.
                                </small>
                            </div>
                            <div class="mt-2">
                                <button class="btn btn-warning reset-question-btn"
                                        data-question-id="{{ question_data.question.id }}"
                                        onclick="resetToAutomatedEvaluation({{ question_data.question.id }})">
                                    <i class="bi bi-arrow-counterclockwise me-2"></i>
                                    Reset subquestion answers above to automated evaluation
                                </button>
                                <small class="text-muted ms-3">
                                    Recalculates all answers using the robust algorithm (case-insensitive, boolean equivalences) and clears admin overrides.
                                </small>
                            </div>
                        </div>
                    </div>
                {% endfor %}
            {% else %}
                <div class="alert alert-warning">
                    <i class="bi bi-exclamation-triangle me-2"></i>
                    {% if hide_overridden %}
                        No unverified subquestion answers found. All answers have been verified!
                    {% else %}
                        No active questions with subquestions found, or no model answers exist yet.
                    {% endif %}
                </div>
            {% endif %}

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

{% block extra_css %}
<style>
    .question-card {
        box-shadow: 0 2px 4px rgba(0,0,0,0.1);
    }

    .subquestion-section {
        border-left: 3px solid #0d6efd;
        padding-left: 15px;
    }

    .table th {
        background-color: #f8f9fa;
        font-weight: 600;
    }

    .verify-question-btn, .reset-question-btn {
        font-weight: 500;
    }

    .verify-question-btn:hover {
        transform: translateY(-1px);
        box-shadow: 0 2px 8px rgba(13,110,253,0.3);
    }

    .reset-question-btn:hover {
        transform: translateY(-1px);
        box-shadow: 0 2px 8px rgba(255,193,7,0.3);
    }

    .admin-override-select:focus {
        border-color: #0d6efd;
        box-shadow: 0 0 0 0.2rem rgba(13,110,253,0.25);
    }

    /* Highlight rows with evaluation mismatches */
    tr.table-warning {
        background-color: #fff3cd !important;
    }

    tr.table-warning td {
        background-color: inherit;
    }

    /* Fresh eval column styling */
    .fresh-eval-cell {
        white-space: nowrap;
    }
</style>
{% endblock %}

{% block extra_js %}
<script>
    // Admin Override Functionality (same as evaluation_detail.html)
    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
                        showFeedback('success', 'Override updated successfully');
                    } else {
                        // Show error and restore original state
                        statusCell.innerHTML = originalHTML;
                        showFeedback('danger', `Error: ${data.error}`);

                        // Reset the dropdown to its original value
                        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);
                    showFeedback('danger', 'Network error occurred');
                });
            });

            // Store the original value for potential reset
            const row = select.closest('tr');
            row.dataset.originalOverride = select.value;
        });
    });

    // Mark question as verified
    function markQuestionVerified(questionId) {
        const btn = document.querySelector(`.verify-question-btn[data-question-id="${questionId}"]`);
        const originalHTML = btn.innerHTML;

        // Show loading state
        btn.disabled = true;
        btn.innerHTML = '<span class="spinner-border spinner-border-sm me-2" role="status"></span>Verifying...';

        // Get CSRF token
        const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;

        // Send request to verify all subquestion answers for this question
        fetch(`/model-evaluation/subquestion-parsing-check/${questionId}/verify/`, {
            method: 'POST',
            headers: {
                'Content-Type': 'application/json',
                'X-CSRFToken': csrfToken
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success) {
                showFeedback('success', data.message);

                // Update button to show success
                btn.innerHTML = '<i class="bi bi-check-circle-fill me-2"></i>Verified!';
                btn.classList.remove('btn-primary');
                btn.classList.add('btn-success');

                // Reload page after 1.5 seconds to reflect changes
                setTimeout(() => {
                    window.location.reload();
                }, 1500);
            } else {
                // Restore button and show error
                btn.disabled = false;
                btn.innerHTML = originalHTML;
                showFeedback('danger', `Error: ${data.error}`);
            }
        })
        .catch(error => {
            console.error('Error marking question as verified:', error);
            btn.disabled = false;
            btn.innerHTML = originalHTML;
            showFeedback('danger', 'Network error occurred');
        });
    }

    // Reset question to automated evaluation
    function resetToAutomatedEvaluation(questionId) {
        // Confirm action since it clears admin overrides
        if (!confirm('This will recalculate ALL subquestion answers using the robust algorithm and clear any admin overrides. Are you sure?')) {
            return;
        }

        const btn = document.querySelector(`.reset-question-btn[data-question-id="${questionId}"]`);
        const originalHTML = btn.innerHTML;

        // Show loading state
        btn.disabled = true;
        btn.innerHTML = '<span class="spinner-border spinner-border-sm me-2" role="status"></span>Resetting...';

        // Get CSRF token
        const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;

        // Send request to reset all subquestion answers for this question
        fetch(`/model-evaluation/subquestion-parsing-check/${questionId}/reset/`, {
            method: 'POST',
            headers: {
                'Content-Type': 'application/json',
                'X-CSRFToken': csrfToken
            }
        })
        .then(response => response.json())
        .then(data => {
            if (data.success) {
                showFeedback('success', data.message);

                // Update button to show success
                btn.innerHTML = '<i class="bi bi-check-circle-fill me-2"></i>Reset Complete!';
                btn.classList.remove('btn-warning');
                btn.classList.add('btn-success');

                // Reload page after 1.5 seconds to reflect changes
                setTimeout(() => {
                    window.location.reload();
                }, 1500);
            } else {
                // Restore button and show error
                btn.disabled = false;
                btn.innerHTML = originalHTML;
                showFeedback('danger', `Error: ${data.error}`);
            }
        })
        .catch(error => {
            console.error('Error resetting to automated evaluation:', error);
            btn.disabled = false;
            btn.innerHTML = originalHTML;
            showFeedback('danger', 'Network error occurred');
        });
    }

    // Helper function to show feedback messages
    function showFeedback(type, message) {
        const feedbackDiv = document.createElement('div');
        feedbackDiv.className = `alert alert-${type} alert-dismissible fade show position-fixed top-0 start-50 translate-middle-x mt-3`;
        feedbackDiv.style.zIndex = '9999';
        feedbackDiv.style.minWidth = '400px';
        feedbackDiv.innerHTML = `
            <i class="bi bi-${type === 'success' ? 'check-circle' : 'exclamation-triangle'}"></i> ${message}
            <button type="button" class="btn-close" data-bs-dismiss="alert"></button>
        `;
        document.body.appendChild(feedbackDiv);

        // Auto-dismiss after 4 seconds
        setTimeout(() => {
            feedbackDiv.remove();
        }, 4000);
    }
</script>
{% endblock %}
