"""
Signal handlers for User-Participant synchronization.

Automatically creates and maintains Participant records when User accounts
are created or updated. This ensures every authenticated user has a
corresponding Participant record for the question/review system.
"""

from django.db.models.signals import post_save
from django.dispatch import receiver
from django.contrib.auth import get_user_model
from django.contrib.auth.signals import user_logged_in
from django.contrib import messages

from participants.models import Participant

User = get_user_model()


def _get_display_name_from_user(user):
    """
    Get display name for a user.

    Returns user's full name if available, otherwise generates
    a name from the email prefix.
    """
    display_name = user.get_full_name()
    if not display_name:
        # Use email prefix as fallback name
        display_name = user.email.split('@')[0].replace('.', ' ').title()
    return display_name


@receiver(post_save, sender=User)
def create_or_update_participant(sender, instance, created, **kwargs):
    """
    Create or update Participant record when User is saved.
    
    For new users:
    - Creates a Participant with contributor role
    - Uses full name from User or email prefix as name
    - Links User and Participant bidirectionally
    
    For existing users:
    - Updates Participant email if changed
    - Updates name if User's name changed
    """
    if created:
        # New user - create corresponding Participant
        display_name = _get_display_name_from_user(instance)

        Participant.objects.create(
            user=instance,
            name=display_name,
            email=instance.email,
            role=Participant.ROLE_CONTRIBUTOR,
            is_active=instance.is_active
        )
    else:
        # Existing user - update Participant if exists
        try:
            participant = instance.participant
            
            # Update email if changed
            if participant.email != instance.email:
                participant.email = instance.email
            
            # Update name if user's name changed and participant uses auto-generated name
            user_full_name = instance.get_full_name()
            if user_full_name and participant.name != user_full_name:
                # Only update if participant name looks auto-generated
                email_prefix = instance.email.split('@')[0].replace('.', ' ').title()
                if participant.name == email_prefix or participant.name == f"Participant {participant.id}":
                    participant.name = user_full_name
            
            # Sync active status
            participant.is_active = instance.is_active
            
            participant.save()
            
        except Participant.DoesNotExist:
            # Edge case: User exists but no Participant - create one
            display_name = _get_display_name_from_user(instance)

            Participant.objects.create(
                user=instance,
                name=display_name,
                email=instance.email,
                role=Participant.ROLE_CONTRIBUTOR,
                is_active=instance.is_active
            )


@receiver(user_logged_in)
def add_welcome_message(sender, request, user, **kwargs):
    """
    Add welcome message when user successfully logs in.
    
    This shows a one-time welcome message after login instead of
    displaying it on every home page visit.
    """
    if user and user.is_authenticated:
        role_display = "user"
        if hasattr(user, 'participant') and user.participant:
            role_display = user.participant.get_role_display()
        
        messages.success(
            request,
            f'<h5 class="alert-heading mb-2">'
            f'<i class="bi bi-check-circle-fill me-2"></i>'
            f'Welcome back, {user.email}!</h5>'
            f'<p class="mb-0">You are logged in as a <strong>{role_display}</strong>.</p>',
            extra_tags='safe'
        )