# Generated by Django 5.2.3 on 2025-06-12 10:11
# Modified to add columns to existing table instead of creating new table

import django.db.models.deletion
from django.conf import settings
from django.db import migrations, models


def create_placeholder_emails(apps, schema_editor):
    """Create placeholder emails for existing participants."""
    Participant = apps.get_model('participants', 'Participant')
    for participant in Participant.objects.all():
        if not participant.email:
            participant.email = f'participant{participant.id}@example.com'
            participant.save()


class Migration(migrations.Migration):

    initial = True

    dependencies = [
        migrations.swappable_dependency(settings.AUTH_USER_MODEL),
    ]

    operations = [
        # First, declare the model exists (for Django's migration tracking)
        migrations.CreateModel(
            name='Participant',
            fields=[
                ('id', models.AutoField(primary_key=True, serialize=False)),
                ('name', models.TextField(blank=True, null=True)),
            ],
            options={
                'db_table': 'participants',
                'managed': False,  # Don't create table, it already exists
            },
        ),
        
        # Now make it managed so we can modify it
        migrations.AlterModelOptions(
            name='participant',
            options={'managed': True, 'db_table': 'participants'},
        ),
        
        # Add the new fields to existing table
        migrations.AddField(
            model_name='participant',
            name='email',
            field=models.EmailField(blank=True, help_text='Email address (synced from user account)', max_length=254, null=True),
        ),
        migrations.AddField(
            model_name='participant',
            name='role',
            field=models.CharField(choices=[('contributor', 'Contributor'), ('reviewer', 'Reviewer'), ('admin', 'Admin')], default='contributor', help_text='User role determining permissions', max_length=20),
        ),
        migrations.AddField(
            model_name='participant',
            name='is_active',
            field=models.BooleanField(default=True, help_text='Whether this participant can access the system'),
        ),
        migrations.AddField(
            model_name='participant',
            name='user',
            field=models.OneToOneField(blank=True, help_text='Linked user account for authentication', null=True, on_delete=django.db.models.deletion.CASCADE, related_name='participant', to=settings.AUTH_USER_MODEL),
        ),
        
        # Run data migration to create placeholder emails
        migrations.RunPython(create_placeholder_emails, reverse_code=migrations.RunPython.noop),
    ]
