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

{% block title %}
    {% if form.instance.pk %}Edit Participant{% else %}Add Participant{% endif %} - IMProofBench
{% endblock %}

{% block page_header %}
<div class="mb-4">
    <nav aria-label="breadcrumb">
        <ol class="breadcrumb">
            <li class="breadcrumb-item">
                <a href="{% url 'participants:list' %}" class="text-decoration-none">
                    <i class="bi bi-people me-1"></i>
                    Participants
                </a>
            </li>
            <li class="breadcrumb-item active">
                {% if form.instance.pk %}Edit {{ form.instance.name }}{% else %}Add New{% endif %}
            </li>
        </ol>
    </nav>
</div>
{% endblock %}

{% block content %}
<div class="row justify-content-center">
    <div class="col-lg-8">
        <!-- Form Card -->
        <div class="card shadow-sm">
            <div class="card-body p-5">
                <!-- Form with crispy forms -->
                {% crispy form %}
            </div>
        </div>
        
        <!-- Additional Help Text -->
        <div class="mt-4 text-center">
            <small class="text-muted">
                <i class="bi bi-info-circle me-1"></i>
                Participants can author questions and review submissions in the benchmark
            </small>
        </div>
    </div>
</div>
{% endblock %}

{% block extra_css %}
<style>
    .card {
        border: none;
        border-radius: 12px;
    }
    
    .form-control-lg {
        border-radius: 8px;
        border: 2px solid #e9ecef;
        transition: all 0.2s ease;
    }
    
    .form-control-lg:focus {
        border-color: #0d6efd;
        box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.15);
    }
    
    .btn-lg {
        border-radius: 8px;
        font-weight: 600;
        letter-spacing: 0.5px;
    }
    
    .breadcrumb {
        background: none;
        padding: 0;
        margin: 0;
        font-size: 0.9rem;
    }
    
    .breadcrumb-item + .breadcrumb-item::before {
        content: "›";
        color: #6c757d;
    }
    
    /* Form validation styling */
    .is-invalid {
        border-color: #dc3545;
    }
    
    .invalid-feedback {
        display: block;
        font-size: 0.875rem;
        margin-top: 0.25rem;
    }
    
    /* Success state styling */
    .is-valid {
        border-color: #198754;
    }
</style>
{% endblock %}

{% block extra_js %}
<script>
// Bootstrap form validation
(function() {
    'use strict';
    
    // Add Bootstrap validation classes to form
    const forms = document.querySelectorAll('.needs-validation');
    
    Array.prototype.slice.call(forms).forEach(function(form) {
        form.addEventListener('submit', function(event) {
            if (!form.checkValidity()) {
                event.preventDefault();
                event.stopPropagation();
            }
            
            form.classList.add('was-validated');
        }, false);
    });
    
    // Real-time validation feedback
    const nameInput = document.querySelector('input[name="name"]');
    if (nameInput) {
        nameInput.addEventListener('input', function() {
            const value = this.value.trim();
            
            // Remove previous validation classes
            this.classList.remove('is-valid', 'is-invalid');
            
            if (value.length >= 2 && value.length <= 100) {
                this.classList.add('is-valid');
            } else if (value.length > 0) {
                this.classList.add('is-invalid');
            }
        });
    }
})();
</script>
{% endblock %}