from django import forms
from crispy_forms.helper import FormHelper
from crispy_forms.layout import Layout, Submit, Row, Column, HTML
from crispy_forms.bootstrap import Alert
from .models import Participant


class ParticipantForm(forms.ModelForm):
    """
    Form for creating and editing participants.
    
    Uses crispy-forms for Bootstrap 5 styling and validation.
    Includes client-side validation for better user experience.
    """
    
    class Meta:
        model = Participant
        fields = ['name', 'email', 'role', 'is_active']
        widgets = {
            'name': forms.TextInput(attrs={
                'placeholder': 'Enter participant name...',
                'class': 'form-control-lg'
            }),
            'email': forms.EmailInput(attrs={
                'placeholder': 'participant@example.com',
                'class': 'form-control'
            }),
            'role': forms.Select(attrs={
                'class': 'form-select'
            }),
            'is_active': forms.CheckboxInput(attrs={
                'class': 'form-check-input'
            })
        }
    
    def __init__(self, *args, **kwargs):
        # Extract user from kwargs if provided to determine permissions
        self.user = kwargs.pop('user', None)
        super().__init__(*args, **kwargs)
        
        # Configure crispy forms helper
        self.helper = FormHelper()
        self.helper.form_method = 'post'
        self.helper.form_class = 'needs-validation'
        self.helper.attrs = {'novalidate': ''}  # Use Bootstrap validation instead of browser default
        
        # Determine if user is admin (for showing role management fields)
        is_admin = (
            self.user and 
            hasattr(self.user, 'participant') and 
            self.user.participant.is_admin
        )
        
        # Build form layout components
        layout_components = [
            HTML('<div class="row justify-content-center"><div class="col-md-8">'),
            
            # Form header
            HTML('''
                <div class="text-center mb-4">
                    <div class="bg-primary bg-gradient rounded-circle d-inline-flex align-items-center justify-content-center mb-3" 
                         style="width: 60px; height: 60px;">
                        <i class="bi bi-person-plus text-white fs-3"></i>
                    </div>
                    <h3 class="mb-1">{% if form.instance.pk %}Edit Participant{% else %}Add New Participant{% endif %}</h3>
                    <p class="text-muted">{% if form.instance.pk %}Update participant information{% else %}Add a new author or reviewer to the benchmark{% endif %}</p>
                </div>
            '''),
            
            # Name field (always visible)
            Row(
                Column(
                    'name',
                    css_class='form-group'
                ),
                css_class='mb-4'
            ),
        ]
        
        # Add admin-only fields
        if is_admin:
            layout_components.extend([
                # Email and role fields for admins
                Row(
                    Column(
                        'email',
                        css_class='form-group col-md-6'
                    ),
                    Column(
                        'role',
                        css_class='form-group col-md-6'
                    ),
                    css_class='mb-4'
                ),
                
                # Active status checkbox
                Row(
                    Column(
                        HTML('''
                            <div class="form-check">
                                <label class="form-check-label" for="{{ form.is_active.id_for_label }}">
                                    {{ form.is_active }}
                                    <strong>{{ form.is_active.label }}</strong>
                                </label>
                                <div class="form-text">{{ form.is_active.help_text }}</div>
                            </div>
                        '''),
                        css_class='form-group'
                    ),
                    css_class='mb-4'
                ),
            ])
        else:
            # Non-admins: hide these fields but include them as hidden
            layout_components.extend([
                HTML('{{ form.email.as_hidden }}'),
                HTML('{{ form.role.as_hidden }}'),
                HTML('{{ form.is_active.as_hidden }}'),
            ])
        
        # Add form actions
        layout_components.extend([
            # Form actions
            HTML('<div class="d-flex justify-content-between align-items-center">'),
            HTML('''
                <a href="{% url 'participants:list' %}" class="btn btn-outline-secondary">
                    <i class="bi bi-arrow-left me-1"></i>
                    Back to List
                </a>
            '''),
            Submit('save', 'Save Participant', css_class='btn btn-primary btn-lg px-4'),
            HTML('</div>'),
            
            HTML('</div></div>')
        ])
        
        # Set the complete layout
        self.helper.layout = Layout(*layout_components)
        
        # Field-specific configurations
        self.fields['name'].required = True
        self.fields['name'].help_text = 'Full name of the participant (required)'
        
        # Configure new fields
        self.fields['email'].required = False
        self.fields['email'].help_text = 'Email address for authentication (optional for existing participants)'
        
        self.fields['role'].help_text = 'User role determines access permissions'
        
        self.fields['is_active'].label = 'Active Status'
        self.fields['is_active'].help_text = 'Inactive participants cannot log in or access the system'
        self.fields['is_active'].initial = True  # Default to active for new participants
        
        # Add Bootstrap validation classes
        for field_name, field in self.fields.items():
            if field_name == 'is_active':
                # Checkbox doesn't need form-control class
                field.widget.attrs.update({
                    'required': field.required,
                })
            else:
                field.widget.attrs.update({
                    'required': field.required,
                    'class': field.widget.attrs.get('class', '') + ' form-control'
                })
    
    def clean_name(self):
        """Validate participant name."""
        name = self.cleaned_data.get('name', '').strip()
        
        if not name:
            raise forms.ValidationError("Participant name is required.")
        
        if len(name) < 2:
            raise forms.ValidationError("Name must be at least 2 characters long.")
        
        if len(name) > 100:
            raise forms.ValidationError("Name must be 100 characters or less.")
        
        # Check for duplicate names (excluding current instance for edits)
        existing = Participant.objects.filter(name__iexact=name)
        if self.instance.pk:
            existing = existing.exclude(pk=self.instance.pk)
        
        if existing.exists():
            raise forms.ValidationError(f"A participant named '{name}' already exists.")
        
        return name