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

{% block title %}Questions - IMProofBench{% endblock %}

{% block page_header %}
<div class="d-flex justify-content-between align-items-center mb-4">
    <div>
        <h2 class="mb-1">Questions</h2>
        <p class="text-muted mb-0">Manage mathematical proof benchmark problems</p>
    </div>
    <div>
        <a href="{% url 'questions:add' %}" class="btn btn-primary">
            <i class="bi bi-plus-lg me-1"></i>
            Add Question
        </a>
    </div>
</div>
{% endblock %}

{% block content %}
<!-- Search and Filter Bar -->
<div class="row mb-4">
    <div class="col-md-8">
        <form method="get" class="d-flex">
            <input 
                type="search" 
                name="search" 
                value="{{ search_query }}" 
                placeholder="Search by title, author, or tags..." 
                class="form-control me-2"
                aria-label="Search questions"
            >
            <select name="status" class="form-select me-2" style="width: auto;">
                <option value="">All Status</option>
                {% for status in available_statuses %}
                    <option value="{{ status.status }}" {% if status_filter == status.status %}selected{% endif %}>
                        {{ status.status|title }}
                    </option>
                {% endfor %}
            </select>
            <button class="btn btn-outline-primary" type="submit">
                <i class="bi bi-search me-1"></i>
                Search
            </button>
            {% if search_query or status_filter %}
                <a href="{% url 'questions:list' %}" class="btn btn-outline-secondary ms-2">
                    <i class="bi bi-x-lg me-1"></i>
                    Clear
                </a>
            {% endif %}
        </form>
    </div>
</div>

<!-- Results Summary -->
{% if search_query or status_filter %}
    <div class="alert alert-info mb-3">
        <i class="bi bi-info-circle me-2"></i>
        Found {{ total_question_count }} question{{ total_question_count|pluralize }}
        {% if search_query %}matching "{{ search_query }}"{% endif %}
        {% if status_filter %}with status "{{ status_filter|title }}"{% endif %}
    </div>
{% endif %}

<!-- Questions Table -->
{% if questions %}
    <div class="card">
        <div class="card-body p-0">
            <div class="table-responsive">
                <table class="table table-hover mb-0">
                    <thead class="table-light">
                        <tr>
                            <th scope="col" class="ps-4">Title</th>
                            <th scope="col">Author</th>
                            <th scope="col">Status</th>
                            <th scope="col">Difficulty</th>
                            <th scope="col">Modified</th>
                            <th scope="col" class="text-center">Actions</th>
                        </tr>
                    </thead>
                    <tbody>
                        {% for question in questions %}
                        <tr{% if question.published %} class="table-success"{% elif question.id in assigned_questions %} class="table-info"{% endif %}>
                            <td class="ps-4">
                                <div>
                                    <a href="{% url 'questions:detail' question.pk %}" class="text-decoration-none fw-medium">
                                        {{ question.title|default:"Untitled Question" }}
                                        {% if question.published %}
                                            <span class="badge bg-success ms-2">
                                                <i class="bi bi-globe me-1"></i>
                                                Public
                                            </span>
                                        {% elif question.id in assigned_questions %}
                                            <span class="badge bg-info ms-2">Review Request</span>
                                        {% endif %}
                                    </a>
                                    {% if question.tags %}
                                        <div class="mt-1">
                                            {% for tag in question.tags|split:"," %}
                                                {% if tag.strip %}
                                                    <span class="badge bg-light text-dark me-1">{{ tag.strip }}</span>
                                                {% endif %}
                                            {% endfor %}
                                        </div>
                                    {% endif %}
                                </div>
                            </td>
                            <td>
                                <div class="d-flex align-items-center">
                                    <div class="avatar bg-secondary text-white rounded-circle d-flex align-items-center justify-content-center me-2" style="width: 32px; height: 32px; font-size: 0.75rem;">
                                        {{ question.author.name|first|upper|default:"?" }}
                                    </div>
                                    <div class="small">
                                        {{ question.author.name|default:"Unknown Author" }}
                                    </div>
                                </div>
                            </td>
                            <td>
                                {% if question.status.status == 'draft' %}
                                    <span class="badge bg-warning text-dark">
                                        <i class="bi bi-pencil-square me-1"></i>
                                        {{ question.status.status|title }}
                                    </span>
                                    {% if question.open_review_count > 0 %}
                                        <br><small class="text-info">{{ question.open_review_count }} open review{{ question.open_review_count|pluralize }}</small>
                                    {% endif %}
                                {% elif question.status.status == 'under_review' %}
                                    <span class="badge bg-info text-dark">
                                        <i class="bi bi-clock me-1"></i>
                                        Under Review
                                    </span>
                                    {% if question.open_review_count > 0 %}
                                        <br><small class="text-muted">{{ question.open_review_count }} open review{{ question.open_review_count|pluralize }}</small>
                                    {% elif question.reviews.count > 0 %}
                                        <br><small class="text-muted">All reviews addressed</small>
                                    {% endif %}
                                {% elif question.status.status == 'approved' %}
                                    <div class="d-flex flex-column align-items-start">
                                        <span class="badge bg-success mb-2">
                                            <i class="bi bi-check-circle me-1"></i>
                                            {{ question.status.status|title }}
                                        </span>
                                        {% if question.reviews.count > 0 %}
                                            <small class="text-muted mb-2">{{ question.reviews.count }} total review{{ question.reviews.count|pluralize }}</small>
                                        {% endif %}
                                        <!-- Activate button for admins only -->
                                        {% if user.participant.is_admin %}
                                            <button type="button" class="btn btn-xs btn-primary activate-question-btn" 
                                                    data-question-id="{{ question.pk }}"
                                                    data-question-title="{{ question.title|default:'Untitled Question' }}"
                                                    title="Activate for evaluation">
                                                <i class="bi bi-play-fill me-1"></i>
                                                Activate
                                            </button>
                                        {% endif %}
                                    </div>
                                {% elif question.status.status == 'active' %}
                                    <div class="d-flex flex-column align-items-start">
                                        <span class="badge badge-purple mb-2">
                                            <i class="bi bi-activity me-1"></i>
                                            Active
                                        </span>
                                        {% if question.reviews.count > 0 %}
                                            <small class="text-muted mb-2">{{ question.reviews.count }} total review{{ question.reviews.count|pluralize }}</small>
                                        {% endif %}
                                        {% if question.has_finalized_grading %}
                                            <small class="text-success mb-2">
                                                <i class="bi bi-check-square-fill me-1"></i>
                                                Grading complete
                                            </small>
                                        {% elif question.released_answer_count > 0 %}
                                            <small class="text-success mb-2">
                                                <i class="bi bi-clipboard-check me-1"></i>
                                                {{ question.released_answer_count }} answer{{ question.released_answer_count|pluralize }} ready
                                            </small>
                                        {% endif %}
                                    </div>
                                {% else %}
                                    <span class="badge bg-secondary">
                                        {{ question.status.status|title }}
                                    </span>
                                {% endif %}
                            </td>
                            <td>
                                <div class="d-flex flex-wrap gap-1">
                                    {% if question.difficulty_background %}
                                        <span class="badge bg-primary" title="Background Knowledge">
                                            B{{ question.difficulty_background }}
                                        </span>
                                    {% endif %}
                                    {% if question.difficulty_reasoning %}
                                        <span class="badge bg-success" title="Reasoning Complexity">
                                            R{{ question.difficulty_reasoning }}
                                        </span>
                                    {% endif %}
                                    {% if question.difficulty_insight %}
                                        <span class="badge bg-warning text-dark" title="Mathematical Insight">
                                            I{{ question.difficulty_insight }}
                                        </span>
                                    {% endif %}
                                    {% if question.difficulty_compute %}
                                        <span class="badge bg-info text-dark" title="Computational Requirements">
                                            C{{ question.difficulty_compute }}
                                        </span>
                                    {% endif %}
                                </div>
                            </td>
                            <td>
                                <div class="small text-muted">
                                    {{ question.last_modified|date:"M j, Y" }}
                                    <br>
                                    <span class="text-muted">{{ question.last_modified|time:"g:i A" }}</span>
                                </div>
                            </td>
                            <td class="text-center">
                                <div class="btn-group btn-group-sm" role="group">
                                    <a href="{% url 'questions:detail' question.pk %}" class="btn btn-outline-info" title="View question">
                                        <i class="bi bi-eye"></i>
                                    </a>
                                    <a href="{% url 'questions:edit' question.pk %}" class="btn btn-outline-primary" title="Edit question">
                                        <i class="bi bi-pencil"></i>
                                    </a>
                                    {% if question.can_grade %}
                                        <a href="{% url 'questions:grading_overview' question.pk %}" class="btn btn-outline-warning" title="Grade model answers">
                                            <i class="bi bi-clipboard-check"></i>
                                        </a>
                                    {% endif %}
                                    <a href="{% url 'questions:delete' question.pk %}" class="btn btn-outline-danger" title="Delete question">
                                        <i class="bi bi-trash"></i>
                                    </a>
                                </div>
                            </td>
                        </tr>
                        {% endfor %}
                    </tbody>
                </table>
            </div>
        </div>
    </div>

    <!-- Pagination -->
    {% if is_paginated %}
        <nav aria-label="Questions pagination" class="mt-4">
            <ul class="pagination justify-content-center">
                {% if page_obj.has_previous %}
                    <li class="page-item">
                        <a class="page-link" href="?page=1{% if search_query %}&search={{ search_query }}{% endif %}{% if status_filter %}&status={{ status_filter }}{% endif %}">
                            <i class="bi bi-chevron-double-left"></i>
                        </a>
                    </li>
                    <li class="page-item">
                        <a class="page-link" href="?page={{ page_obj.previous_page_number }}{% if search_query %}&search={{ search_query }}{% endif %}{% if status_filter %}&status={{ status_filter }}{% endif %}">
                            <i class="bi bi-chevron-left"></i>
                        </a>
                    </li>
                {% endif %}

                <li class="page-item active">
                    <span class="page-link">
                        Page {{ page_obj.number }} of {{ page_obj.paginator.num_pages }}
                    </span>
                </li>

                {% if page_obj.has_next %}
                    <li class="page-item">
                        <a class="page-link" href="?page={{ page_obj.next_page_number }}{% if search_query %}&search={{ search_query }}{% endif %}{% if status_filter %}&status={{ status_filter }}{% endif %}">
                            <i class="bi bi-chevron-right"></i>
                        </a>
                    </li>
                    <li class="page-item">
                        <a class="page-link" href="?page={{ page_obj.paginator.num_pages }}{% if search_query %}&search={{ search_query }}{% endif %}{% if status_filter %}&status={{ status_filter }}{% endif %}">
                            <i class="bi bi-chevron-double-right"></i>
                        </a>
                    </li>
                {% endif %}
            </ul>
        </nav>
    {% endif %}

{% else %}
    <!-- Empty State -->
    <div class="text-center py-5">
        <div class="mb-3">
            <i class="bi bi-file-earmark-text text-muted" style="font-size: 4rem;"></i>
        </div>
        {% if search_query or status_filter %}
            <h4 class="text-muted">No questions found</h4>
            <p class="text-muted">
                No questions match your search
                {% if search_query %}for "{{ search_query }}"{% endif %}
                {% if status_filter %}with status "{{ status_filter|title }}"{% endif %}
            </p>
            <a href="{% url 'questions:list' %}" class="btn btn-outline-primary">
                <i class="bi bi-arrow-left me-1"></i>
                View all questions
            </a>
        {% else %}
            <h4 class="text-muted">No questions yet</h4>
            <p class="text-muted">Get started by adding your first mathematical proof question</p>
            <a href="{% url 'questions:add' %}" class="btn btn-primary">
                <i class="bi bi-plus-lg me-1"></i>
                Add First Question
            </a>
        {% endif %}
    </div>
{% endif %}

<!-- Activation Confirmation Modal -->
<div class="modal fade" id="activateQuestionModal" tabindex="-1" aria-labelledby="activateQuestionModalLabel" aria-hidden="true">
    <div class="modal-dialog">
        <div class="modal-content">
            <div class="modal-header">
                <h5 class="modal-title" id="activateQuestionModalLabel">
                    <i class="bi bi-play-fill me-2"></i>
                    Activate Question
                </h5>
                <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
            </div>
            <div class="modal-body">
                <div class="alert alert-info">
                    <i class="bi bi-info-circle me-2"></i>
                    <strong>This will:</strong>
                    <ul class="mb-0 mt-2">
                        <li>Change question status from "Approved" to "Active"</li>
                        <li>Queue evaluations for all active models in the system</li>
                        <li>Begin automatic evaluation processing</li>
                    </ul>
                </div>
                <p class="mb-0">
                    Are you sure you want to activate 
                    <strong id="question-title-placeholder">this question</strong> 
                    for evaluation?
                </p>
            </div>
            <div class="modal-footer">
                <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Cancel</button>
                <form id="activate-question-form" method="post" style="display: inline;">
                    {% csrf_token %}
                    <button type="submit" class="btn btn-primary">
                        <i class="bi bi-play-fill me-1"></i>
                        Activate Question
                    </button>
                </form>
            </div>
        </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">
<style>
    .avatar {
        font-weight: 600;
    }
    
    .table th {
        border-top: none;
        font-weight: 600;
        font-size: 0.875rem;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
    
    .badge {
        font-size: 0.7rem;
        font-weight: 600;
    }
    
    .btn-group-sm .btn {
        padding: 0.25rem 0.5rem;
    }
    
    /* Extra small button for table rows */
    .btn-xs {
        padding: 0.125rem 0.25rem;
        font-size: 0.7rem;
        line-height: 1.2;
        border-radius: 0.25rem;
    }
    
    /* Custom badge colors */
    .badge-purple { 
        background-color: #6f42c1 !important; 
        color: white !important;
    }
    
    /* Difficulty badge colors */
    .badge.bg-primary { background-color: #0d6efd !important; }  /* Background */
    .badge.bg-success { background-color: #198754 !important; }  /* Reasoning */
    .badge.bg-warning { background-color: #ffc107 !important; }  /* Insight */
    .badge.bg-info { background-color: #0dcaf0 !important; }     /* Compute */
</style>
{% endblock %}

{% block extra_js %}
<script>
    document.addEventListener('DOMContentLoaded', function() {
        // Handle activate question button clicks
        const activateButtons = document.querySelectorAll('.activate-question-btn');
        const modal = document.getElementById('activateQuestionModal');
        const form = document.getElementById('activate-question-form');
        const titlePlaceholder = document.getElementById('question-title-placeholder');
        
        activateButtons.forEach(button => {
            button.addEventListener('click', function() {
                const questionId = this.getAttribute('data-question-id');
                const questionTitle = this.getAttribute('data-question-title');
                
                // Update modal content
                titlePlaceholder.textContent = `"${questionTitle}"`;
                
                // Update form action
                form.action = `/questions/${questionId}/activate/`;
                
                // Show modal
                const modalInstance = new bootstrap.Modal(modal);
                modalInstance.show();
            });
        });
    });
</script>
{% endblock %}
