# Generated by Django 5.0.2 on 2025-11-20 19:16

import django.db.models.deletion
import django.utils.timezone
import uuid
from django.db import migrations, models


class Migration(migrations.Migration):

    initial = True

    dependencies = [
        ('company', '0001_initial'),
        ('projects', '0001_initial'),
        ('stamps', '0001_initial'),
        ('user', '0001_initial'),
    ]

    operations = [
        migrations.CreateModel(
            name='PayrollIntegration',
            fields=[
                ('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
                ('provider', models.CharField(choices=[('netvisor', 'Netvisor'), ('procounter', 'ProCounter'), ('none', 'None')], default='none', max_length=50)),
                ('is_active', models.BooleanField(default=False)),
                ('api_endpoint', models.URLField(blank=True, help_text='API endpoint URL for the payroll system', null=True)),
                ('api_key', models.CharField(blank=True, help_text='API key or client ID (stored in plain text for now)', max_length=255)),
                ('api_secret', models.CharField(blank=True, help_text='API secret or client secret (stored in plain text for now)', max_length=255)),
                ('last_sync', models.DateTimeField(blank=True, null=True)),
                ('sync_frequency', models.CharField(choices=[('daily', 'Daily'), ('weekly', 'Weekly'), ('manual', 'Manual')], default='manual', max_length=20)),
                ('created_at', models.DateTimeField(default=django.utils.timezone.now)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('company', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='payroll_integration', to='company.company')),
            ],
            options={
                'db_table': 'payroll_integrations',
                'ordering': ['-created_at'],
            },
        ),
        migrations.CreateModel(
            name='PayrollSubmission',
            fields=[
                ('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
                ('period_start', models.DateField()),
                ('period_end', models.DateField()),
                ('submission_status', models.CharField(choices=[('pending', 'Pending'), ('submitted', 'Submitted'), ('failed', 'Failed'), ('confirmed', 'Confirmed')], default='pending', max_length=20)),
                ('external_reference_id', models.CharField(blank=True, help_text='Reference ID from payroll system', max_length=255)),
                ('submitted_at', models.DateTimeField(blank=True, null=True)),
                ('error_message', models.TextField(blank=True)),
                ('created_at', models.DateTimeField(default=django.utils.timezone.now)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('payroll_integration', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='submissions', to='payroll.payrollintegration')),
                ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='payroll_submissions', to='user.user')),
            ],
            options={
                'db_table': 'payroll_submissions',
                'ordering': ['-created_at'],
            },
        ),
        migrations.CreateModel(
            name='EmployeeMapping',
            fields=[
                ('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
                ('external_employee_id', models.CharField(help_text='Employee ID in the payroll system', max_length=100)),
                ('is_active', models.BooleanField(default=True)),
                ('created_at', models.DateTimeField(default=django.utils.timezone.now)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='payroll_mappings', to='user.user')),
                ('payroll_integration', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='employee_mappings', to='payroll.payrollintegration')),
            ],
            options={
                'db_table': 'payroll_employee_mappings',
                'ordering': ['-created_at'],
                'unique_together': {('user', 'payroll_integration')},
            },
        ),
        migrations.CreateModel(
            name='PayrollSubmissionStamp',
            fields=[
                ('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
                ('created_at', models.DateTimeField(default=django.utils.timezone.now)),
                ('stamp', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='payroll_submissions', to='stamps.stamp')),
                ('submission', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='submission_stamps', to='payroll.payrollsubmission')),
            ],
            options={
                'db_table': 'payroll_submission_stamps',
                'unique_together': {('submission', 'stamp')},
            },
        ),
        migrations.CreateModel(
            name='ProjectMapping',
            fields=[
                ('id', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
                ('external_project_code', models.CharField(help_text='Project code in the payroll system', max_length=100)),
                ('is_active', models.BooleanField(default=True)),
                ('created_at', models.DateTimeField(default=django.utils.timezone.now)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('payroll_integration', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='project_mappings', to='payroll.payrollintegration')),
                ('project', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='payroll_mappings', to='projects.project')),
            ],
            options={
                'db_table': 'payroll_project_mappings',
                'ordering': ['-created_at'],
                'unique_together': {('project', 'payroll_integration')},
            },
        ),
    ]
