{% extends 'base.html' %}

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

{% block page_header %}
<div class="d-flex justify-content-between align-items-center mb-4">
    <div>
        <h2 class="mb-1">Participants</h2>
        <p class="text-muted mb-0">Manage authors and reviewers in the benchmark</p>
    </div>
    {% if user.is_authenticated and user.participant.is_admin %}
    <div>
        <a href="{% url 'participants:add' %}" class="btn btn-primary">
            <i class="bi bi-plus-lg me-1"></i>
            Add Participant
        </a>
    </div>
    {% endif %}
</div>
{% endblock %}

{% block content %}
<!-- Search Bar -->
<div class="row mb-4">
    <div class="col-md-6">
        <form method="get" class="d-flex">
            <input 
                type="search" 
                name="search" 
                value="{{ search_query }}" 
                placeholder="Search participants by name..." 
                class="form-control me-2"
                aria-label="Search participants"
            >
            <button class="btn btn-outline-primary" type="submit">
                <i class="bi bi-search"></i>
            </button>
            {% if search_query %}
                <a href="{% url 'participants:list' %}" class="btn btn-outline-secondary ms-2">
                    <i class="bi bi-x-lg"></i>
                </a>
            {% endif %}
        </form>
    </div>
</div>

<!-- Results Summary -->
{% if search_query %}
    <div class="alert alert-info mb-3">
        <i class="bi bi-info-circle me-2"></i>
        Found {{ participants|length }} participant{{ participants|length|pluralize }} matching "{{ search_query }}"
    </div>
{% endif %}

<!-- Participants Table -->
{% if participants %}
    <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" rowspan="2" class="ps-4 align-middle">ID</th>
                            <th scope="col" rowspan="2" class="align-middle">
                                Name
                                <span class="ms-1">
                                    <a href="?sort=name&order={% if current_sort == 'name' %}{% if current_order == 'asc' %}desc{% else %}asc{% endif %}{% else %}asc{% endif %}{% if search_query %}&search={{ search_query }}{% endif %}&page={{ page_obj.number|default:1 }}" 
                                       class="text-decoration-none text-muted">
                                        {% if current_sort == 'name' %}
                                            {% if current_order == 'asc' %}
                                                <i class="bi bi-arrow-up-short"></i>
                                            {% else %}
                                                <i class="bi bi-arrow-down-short"></i>
                                            {% endif %}
                                        {% else %}
                                            <i class="bi bi-arrow-down-up"></i>
                                        {% endif %}
                                    </a>
                                </span>
                            </th>
                            <th scope="col" rowspan="2" class="align-middle">{% if user.is_authenticated and user.participant and user.participant.role == 'admin' %}Email{% endif %}</th>
                            <th scope="col" rowspan="2" class="align-middle">Role</th>
                            <th scope="col" colspan="3" class="text-center">Questions</th>
                            <th scope="col" rowspan="2" class="text-center align-middle">
                                Model Stumps
                                <i class="bi bi-info-circle text-muted ms-1" data-bs-toggle="tooltip" 
                                   data-bs-placement="top"
                                   title="Number of subquestions where Tier 1 models (GPT-5, Claude Opus 4.1, Gemini 2.5 Pro, Grok 4) gave incorrect answers. Higher numbers indicate more challenging questions that stump top AI models."></i>
                                <span class="ms-1">
                                    <a href="?sort=model_stumps&order={% if current_sort == 'model_stumps' %}{% if current_order == 'asc' %}desc{% else %}asc{% endif %}{% else %}desc{% endif %}{% if search_query %}&search={{ search_query }}{% endif %}&page={{ page_obj.number|default:1 }}" 
                                       class="text-decoration-none text-muted">
                                        {% if current_sort == 'model_stumps' %}
                                            {% if current_order == 'asc' %}
                                                <i class="bi bi-arrow-up-short"></i>
                                            {% else %}
                                                <i class="bi bi-arrow-down-short"></i>
                                            {% endif %}
                                        {% else %}
                                            <i class="bi bi-arrow-down-up"></i>
                                        {% endif %}
                                    </a>
                                </span>
                            </th>
                            <th scope="col" rowspan="2" class="text-center align-middle">Actions</th>
                        </tr>
                        <tr>
                            <th scope="col" class="text-center">
                                Under Review
                                <span class="ms-1">
                                    <a href="?sort=under_review&order={% if current_sort == 'under_review' %}{% if current_order == 'asc' %}desc{% else %}asc{% endif %}{% else %}desc{% endif %}{% if search_query %}&search={{ search_query }}{% endif %}" 
                                       class="text-decoration-none text-muted">
                                        {% if current_sort == 'under_review' %}
                                            {% if current_order == 'asc' %}
                                                <i class="bi bi-arrow-up-short"></i>
                                            {% else %}
                                                <i class="bi bi-arrow-down-short"></i>
                                            {% endif %}
                                        {% else %}
                                            <i class="bi bi-arrow-down-up"></i>
                                        {% endif %}
                                    </a>
                                </span>
                            </th>
                            <th scope="col" class="text-center">
                                Accepted
                                <span class="ms-1">
                                    <a href="?sort=approved&order={% if current_sort == 'approved' %}{% if current_order == 'asc' %}desc{% else %}asc{% endif %}{% else %}desc{% endif %}{% if search_query %}&search={{ search_query }}{% endif %}&page={{ page_obj.number|default:1 }}" 
                                       class="text-decoration-none text-muted">
                                        {% if current_sort == 'approved' %}
                                            {% if current_order == 'asc' %}
                                                <i class="bi bi-arrow-up-short"></i>
                                            {% else %}
                                                <i class="bi bi-arrow-down-short"></i>
                                            {% endif %}
                                        {% else %}
                                            <i class="bi bi-arrow-down-up"></i>
                                        {% endif %}
                                    </a>
                                </span>
                            </th>
                            <th scope="col" class="text-center">
                                Total
                                <span class="ms-1">
                                    <a href="?sort=total&order={% if current_sort == 'total' %}{% if current_order == 'asc' %}desc{% else %}asc{% endif %}{% else %}desc{% endif %}{% if search_query %}&search={{ search_query }}{% endif %}&page={{ page_obj.number|default:1 }}" 
                                       class="text-decoration-none text-muted">
                                        {% if current_sort == 'total' %}
                                            {% if current_order == 'asc' %}
                                                <i class="bi bi-arrow-up-short"></i>
                                            {% else %}
                                                <i class="bi bi-arrow-down-short"></i>
                                            {% endif %}
                                        {% else %}
                                            <i class="bi bi-arrow-down-up"></i>
                                        {% endif %}
                                    </a>
                                </span>
                            </th>
                        </tr>
                    </thead>
                    <tbody>
                        {% for participant in participants %}
                        <tr>
                            <td class="ps-4">
                                <span class="badge bg-light text-dark">{{ participant.id }}</span>
                            </td>
                            <td>
                                <div class="d-flex align-items-center">
                                    <div class="avatar bg-primary text-white rounded-circle d-flex align-items-center justify-content-center me-3" style="width: 40px; height: 40px;">
                                        {{ participant.name|first|upper|default:"?" }}
                                    </div>
                                    <div>
                                        <div class="fw-medium">{{ participant.name|default:"Unnamed Participant" }}</div>
                                        <small class="text-muted">Participant #{{ participant.id }}</small>
                                    </div>
                                </div>
                            </td>
                            <td>
                                <div>
                                    {% if user.is_authenticated and user.participant and user.participant.role == 'admin' %}
                                        {% if participant.email %}
                                            <div class="fw-medium">{{ participant.email }}</div>
                                            {% if participant.user %}
                                                <small class="text-success"><i class="bi bi-check-circle me-1"></i>Account linked</small>
                                            {% else %}
                                                <small class="text-muted"><i class="bi bi-person me-1"></i>No account</small>
                                            {% endif %}
                                        {% else %}
                                            <span class="text-muted">No email</span>
                                        {% endif %}
                                    {% endif %}
                                </div>
                            </td>
                            <td>
                                {% if participant.role == 'admin' %}
                                    <span class="badge bg-danger">Admin</span>
                                {% elif participant.role == 'reviewer' %}
                                    <span class="badge bg-warning">Reviewer</span>
                                {% else %}
                                    <span class="badge bg-secondary">Contributor</span>
                                {% endif %}
                                {% if not participant.is_active %}
                                    <small class="text-muted d-block">Inactive</small>
                                {% endif %}
                            </td>
                            <td class="text-center">{{ participant.under_review_count }}</td>
                            <td class="text-center">{{ participant.approved_count }}</td>
                            <td class="text-center fw-bold">{{ participant.total_count }}</td>
                            <td class="text-center">
                                {% if participant.total_model_answers > 0 %}
                                    {{ participant.incorrect_answers }}
                                {% else %}
                                    <span class="text-muted">-</span>
                                {% endif %}
                            </td>
                            <td class="text-center">
                                {% if user.is_authenticated and user.participant.is_admin %}
                                <div class="btn-group btn-group-sm" role="group">
                                    <a href="{% url 'participants:edit' participant.pk %}" class="btn btn-outline-primary" title="Edit participant">
                                        <i class="bi bi-pencil"></i>
                                    </a>
                                    <a href="{% url 'participants:delete' participant.pk %}" class="btn btn-outline-danger" title="Delete participant">
                                        <i class="bi bi-trash"></i>
                                    </a>
                                </div>
                                {% else %}
                                <span class="text-muted">-</span>
                                {% endif %}
                            </td>
                        </tr>
                        {% endfor %}
                    </tbody>
                </table>
            </div>
        </div>
    </div>

    <!-- Pagination -->
    {% if is_paginated %}
        <nav aria-label="Participants 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 %}&sort={{ current_sort }}&order={{ current_order }}">
                            <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 %}&sort={{ current_sort }}&order={{ current_order }}">
                            <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 %}&sort={{ current_sort }}&order={{ current_order }}">
                            <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 %}&sort={{ current_sort }}&order={{ current_order }}">
                            <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-people text-muted" style="font-size: 4rem;"></i>
        </div>
        {% if search_query %}
            <h4 class="text-muted">No participants found</h4>
            <p class="text-muted">No participants match your search for "{{ search_query }}"</p>
            <a href="{% url 'participants:list' %}" class="btn btn-outline-primary">
                <i class="bi bi-arrow-left me-1"></i>
                View all participants
            </a>
        {% else %}
            <h4 class="text-muted">No participants yet</h4>
            <p class="text-muted">Get started by adding your first participant to the benchmark</p>
            {% if user.is_authenticated and user.participant.is_admin %}
            <a href="{% url 'participants:add' %}" class="btn btn-primary">
                <i class="bi bi-plus-lg me-1"></i>
                Add First Participant
            </a>
            {% endif %}
        {% endif %}
    </div>
{% endif %}
{% 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-size: 0.875rem;
        font-weight: 600;
    }
    
    .table th {
        border-top: none;
        font-weight: 600;
        font-size: 0.875rem;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }
    
    .btn-group-sm .btn {
        padding: 0.25rem 0.5rem;
    }
</style>
{% endblock %}

{% block extra_js %}
<script>
    // Initialize Bootstrap tooltips
    document.addEventListener('DOMContentLoaded', function() {
        var tooltipTriggerList = [].slice.call(document.querySelectorAll('[data-bs-toggle="tooltip"]'));
        var tooltipList = tooltipTriggerList.map(function (tooltipTriggerEl) {
            return new bootstrap.Tooltip(tooltipTriggerEl);
        });
    });
</script>
{% endblock %}
