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

{% block title %}Review Question: {{ question.title|default:"Question" }} - IMProofBench{% endblock %}

{% block page_header %}
<div class="mb-4">
    <nav aria-label="breadcrumb">
        <ol class="breadcrumb">
            <li class="breadcrumb-item">
                <a href="{% url 'questions:list' %}" class="text-decoration-none">
                    <i class="bi bi-file-earmark-text me-1"></i>
                    Questions
                </a>
            </li>
            <li class="breadcrumb-item">
                <a href="{% url 'questions:detail' question.pk %}" class="text-decoration-none">
                    {{ question.title|default:"Question Details"|truncatechars:50 }}
                </a>
            </li>
            <li class="breadcrumb-item active">
                Review
            </li>
        </ol>
    </nav>
</div>
{% endblock %}

{% block content %}
<div class="row">
    <div class="col-lg-6">
        <!-- Question Preview -->
        <div class="card shadow-sm mb-4">
            <div class="card-header bg-white">
                <h5 class="mb-0">
                    <i class="bi bi-file-earmark-text me-2"></i>
                    Question to Review
                    {% if responding_to_review %}
                        <small class="text-muted ms-2">(Following up on your previous review)</small>
                    {% endif %}
                </h5>
            </div>
            <div class="card-body">
                <h6 class="text-primary mb-3">{{ question.title|default:"Untitled Question" }}</h6>
                
                <!-- Question Content -->
                <div class="mathematical-content p-3 bg-light rounded mb-3">
                    {% if question.text %}
                        {{ question.text|markdown_latex }}
                    {% else %}
                        <p class="text-muted fst-italic">No question text provided.</p>
                    {% endif %}
                </div>
                
                <!-- Solution (if provided) -->
                {% if question.solution %}
                <div class="mt-3">
                    <h6 class="text-success mb-2">
                        <i class="bi bi-lightbulb me-1"></i>
                        Author's Solution
                    </h6>
                    <div class="mathematical-content p-3 bg-light rounded">
                        {{ question.solution|markdown_latex }}
                    </div>
                </div>
                {% endif %}
                
                <!-- Metadata -->
                <div class="mt-3 row g-2 small text-muted">
                    <div class="col-6">
                        <strong>Author:</strong> {{ question.author.name|default:"Unknown" }}
                    </div>
                    <div class="col-6">
                        <strong>Created:</strong> {{ question.creation_time|date:"M j, Y" }}
                    </div>
                    {% if question.tags %}
                    <div class="col-12">
                        <strong>Tags:</strong> {{ question.tags }}
                    </div>
                    {% endif %}
                </div>
                
                <!-- Difficulty Ratings -->
                {% if question.difficulty_background or question.difficulty_reasoning or question.difficulty_insight or question.difficulty_compute %}
                <div class="mt-3">
                    <h6 class="text-muted mb-2">Difficulty Ratings (1-5)</h6>
                    <div class="row g-2 small">
                        {% if question.difficulty_background %}
                        <div class="col-6">
                            <span class="badge bg-primary">{{ question.difficulty_background }}</span> Background
                        </div>
                        {% endif %}
                        {% if question.difficulty_reasoning %}
                        <div class="col-6">
                            <span class="badge bg-success">{{ question.difficulty_reasoning }}</span> Reasoning
                        </div>
                        {% endif %}
                        {% if question.difficulty_insight %}
                        <div class="col-6">
                            <span class="badge bg-warning text-dark">{{ question.difficulty_insight }}</span> Insight
                        </div>
                        {% endif %}
                        {% if question.difficulty_compute %}
                        <div class="col-6">
                            <span class="badge bg-info text-dark">{{ question.difficulty_compute }}</span> Compute
                        </div>
                        {% endif %}
                    </div>
                </div>
                {% endif %}
                
                <!-- Subquestions -->
                {% if subquestions %}
                <div class="mt-4">
                    <h6 class="text-primary mb-3">
                        <i class="bi bi-list-ol me-1"></i>
                        Subquestions
                    </h6>
                    {% for subquestion in subquestions %}
                    <div class="subquestion mb-3 p-3 border rounded bg-light">
                        <div class="d-flex justify-content-between align-items-start mb-2">
                            <h6 class="text-primary mb-0">
                                Subquestion {{ subquestion.subquestion_order }}
                            </h6>
                            {% if subquestion.points %}
                                <span class="badge bg-primary">{{ subquestion.points }} pts</span>
                            {% endif %}
                        </div>
                        
                        <div class="mathematical-content mb-3">
                            {% if subquestion.text %}
                                {{ subquestion.text|markdown_latex }}
                            {% else %}
                                <p class="text-muted">No text provided.</p>
                            {% endif %}
                        </div>
                        
                        {% if subquestion.answer %}
                        <div class="mb-2">
                            <strong class="text-success">Answer:</strong>
                            <code class="bg-white px-2 py-1 rounded border">{{ subquestion.answer }}</code>
                        </div>
                        {% endif %}
                        
                        {% if subquestion.rationale %}
                        <div class="small text-muted">
                            <strong>Rationale:</strong> {{ subquestion.rationale }}
                        </div>
                        {% endif %}
                    </div>
                    {% endfor %}
                </div>
                {% endif %}
            </div>
        </div>
    </div>
    
    <div class="col-lg-6">
        <!-- Review Form -->
        {% crispy form %}
    </div>
</div>
{% endblock %}

{% block extra_js %}
{{ form.media.js }}

<script>
// Manual toggle function for guidelines
function toggleGuidelines() {
    const target = document.getElementById('guidelinesCollapse');
    const chevron = document.getElementById('guidelinesChevron');
    
    if (target.style.display === 'none' || target.style.display === '') {
        target.style.display = 'block';
        chevron.className = 'bi bi-chevron-up float-end';
    } else {
        target.style.display = 'none';
        chevron.className = 'bi bi-chevron-down float-end';
    }
}

function confirmDeclineReview() {
    if (confirm('Are you sure you want to decline this review request? This will remove the question from your review assignments.')) {
        // Create form and submit
        const form = document.createElement('form');
        form.method = 'POST';
        form.action = '{% url "review_invitations:decline_after_accept" question.pk %}';
        
        // Add CSRF token
        const csrfToken = document.querySelector('[name=csrfmiddlewaretoken]').value;
        const csrfInput = document.createElement('input');
        csrfInput.type = 'hidden';
        csrfInput.name = 'csrfmiddlewaretoken';
        csrfInput.value = csrfToken;
        form.appendChild(csrfInput);
        
        document.body.appendChild(form);
        form.submit();
    }
}
</script>
{% endblock %}

{% block extra_css %}
{{ form.media.css }}
<style>
    .mathematical-content {
        line-height: 1.8;
        font-size: 1.05rem;
    }
    
    .breadcrumb {
        background: none;
        padding: 0;
        margin: 0;
        font-size: 0.9rem;
    }
    
    .breadcrumb-item + .breadcrumb-item::before {
        content: "›";
        color: #6c757d;
    }
    
    .card {
        border: 1px solid #dee2e6;
    }
    
    .badge {
        font-size: 0.8rem;
        font-weight: 500;
    }
</style>
{% endblock %}