# Generated by Django 6.0.3 on 2026-03-30 07:49

import django.db.models.deletion
import django.utils.timezone
from django.conf import settings
from django.db import migrations, models


class Migration(migrations.Migration):

    dependencies = [
        ('MASTERAPP', '0007_returnrequestimage_servicerequestimage'),
    ]

    operations = [
        migrations.CreateModel(
            name='CashbackRule',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('is_active', models.BooleanField(default=True)),
                ('is_deleted', models.BooleanField(default=False)),
                ('extra_data', models.JSONField(blank=True, default=dict, null=True)),
                ('title', models.CharField(max_length=200)),
                ('description', models.TextField(blank=True, null=True)),
                ('rule_type', models.CharField(choices=[('order_amount', 'Order Amount'), ('cumulative_spend', 'Cumulative Spend')], max_length=30)),
                ('threshold_amount', models.DecimalField(decimal_places=2, max_digits=12)),
                ('reward_amount', models.DecimalField(decimal_places=2, max_digits=12)),
                ('cumulative_days', models.PositiveIntegerField(default=0)),
                ('credit_on_status', models.CharField(choices=[('paid', 'Paid'), ('delivered', 'Delivered')], default='delivered', max_length=20)),
                ('start_date', models.DateTimeField()),
                ('end_date', models.DateTimeField()),
                ('show_progress_hint', models.BooleanField(default=True)),
                ('progress_message', models.CharField(blank=True, max_length=255, null=True)),
                ('priority', models.PositiveIntegerField(default=0)),
            ],
            options={
                'db_table': 'cashback_rule',
                'ordering': ['priority', 'threshold_amount'],
            },
        ),
        migrations.CreateModel(
            name='CashbackRewardLog',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('is_active', models.BooleanField(default=True)),
                ('is_deleted', models.BooleanField(default=False)),
                ('extra_data', models.JSONField(blank=True, default=dict, null=True)),
                ('reward_key', models.CharField(max_length=255, unique=True)),
                ('credited_amount', models.DecimalField(decimal_places=2, default=0.0, max_digits=12)),
                ('credited_at', models.DateTimeField(default=django.utils.timezone.now)),
                ('order', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='cashback_reward_logs', to='MASTERAPP.order')),
                ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='cashback_reward_logs', to=settings.AUTH_USER_MODEL)),
                ('rule', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='reward_logs', to='MASTERAPP.cashbackrule')),
            ],
            options={
                'db_table': 'cashback_reward_log',
                'ordering': ['-created_at'],
            },
        ),
        migrations.CreateModel(
            name='CashbackWallet',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('is_active', models.BooleanField(default=True)),
                ('is_deleted', models.BooleanField(default=False)),
                ('extra_data', models.JSONField(blank=True, default=dict, null=True)),
                ('available_balance', models.DecimalField(decimal_places=2, default=0.0, max_digits=12)),
                ('locked_balance', models.DecimalField(decimal_places=2, default=0.0, max_digits=12)),
                ('total_earned', models.DecimalField(decimal_places=2, default=0.0, max_digits=12)),
                ('total_redeemed', models.DecimalField(decimal_places=2, default=0.0, max_digits=12)),
                ('total_expired', models.DecimalField(decimal_places=2, default=0.0, max_digits=12)),
                ('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='cashback_wallet', to=settings.AUTH_USER_MODEL)),
            ],
            options={
                'db_table': 'cashback_wallet',
                'ordering': ['-created_at'],
            },
        ),
        migrations.CreateModel(
            name='CashbackTransaction',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('updated_at', models.DateTimeField(auto_now=True)),
                ('is_active', models.BooleanField(default=True)),
                ('is_deleted', models.BooleanField(default=False)),
                ('extra_data', models.JSONField(blank=True, default=dict, null=True)),
                ('transaction_type', models.CharField(choices=[('credit', 'Credit'), ('debit', 'Debit'), ('expire', 'Expire'), ('reverse', 'Reverse')], max_length=20)),
                ('source_type', models.CharField(choices=[('order_reward', 'Order Reward'), ('cumulative_reward', 'Cumulative Reward'), ('wallet_redeem', 'Wallet Redeem'), ('manual', 'Manual')], max_length=30)),
                ('amount', models.DecimalField(decimal_places=2, max_digits=12)),
                ('balance_after_transaction', models.DecimalField(decimal_places=2, default=0.0, max_digits=12)),
                ('remark', models.CharField(blank=True, max_length=255, null=True)),
                ('expires_at', models.DateTimeField(blank=True, null=True)),
                ('order', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='cashback_transactions', to='MASTERAPP.order')),
                ('rule', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='cashback_transactions', to='MASTERAPP.cashbackrule')),
                ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='cashback_transactions', to=settings.AUTH_USER_MODEL)),
                ('wallet', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='transactions', to='MASTERAPP.cashbackwallet')),
            ],
            options={
                'db_table': 'cashback_transaction',
                'ordering': ['-created_at'],
            },
        ),
    ]
