# Generated by Django 5.1 on 2025-01-23 05:14

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


class Migration(migrations.Migration):

    initial = True

    dependencies = [
        ('shops', '0001_initial'),
        migrations.swappable_dependency(settings.AUTH_USER_MODEL),
    ]

    operations = [
        migrations.CreateModel(
            name='CustomProduct',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('item_name', models.CharField(max_length=120)),
                ('item_code', models.CharField(max_length=120)),
                ('item_description', models.TextField(max_length=1300)),
                ('veg_or_non_veg_status', models.CharField(choices=[('Veg', 'Veg'), ('Non Veg', 'Non Veg')], max_length=100)),
                ('min_size', models.PositiveIntegerField(help_text='Minimum size of the product')),
                ('max_size', models.PositiveIntegerField(help_text='Maximum size of the product')),
                ('size_unit', models.CharField(choices=[('g', 'g'), ('kg', 'kg'), ('ml', 'ml'), ('l', 'l')], default='g', help_text='Unit of size (grams, kilograms, milliliters, etc.)', max_length=20)),
                ('availability', models.CharField(choices=[('Available', 'Available'), ('Disabled', 'Disabled'), ('Out of Stock', 'Out of Stock')], default='Available', max_length=20)),
                ('created_date', models.DateTimeField(auto_now_add=True, null=True)),
                ('updated_date', models.DateTimeField(auto_now=True, null=True)),
            ],
        ),
        migrations.CreateModel(
            name='ProductCategory',
            fields=[
                ('uuid', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False, unique=True)),
                ('category_name', models.CharField(max_length=100)),
                ('category_code', models.CharField(max_length=200, unique=True)),
                ('created_at', models.DateTimeField(auto_now_add=True, null=True)),
                ('updated_date', models.DateTimeField(auto_now=True, null=True)),
                ('icon', models.ImageField(blank=True, null=True, upload_to='icons/')),
                ('standard_image', models.ImageField(blank=True, null=True, upload_to='standard_images/')),
                ('banner_image', models.ImageField(blank=True, null=True, upload_to='banners/')),
            ],
        ),
        migrations.CreateModel(
            name='CustomProductImage',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('image', models.ImageField(upload_to='custom_product_images/')),
                ('created_date', models.DateTimeField(auto_now_add=True)),
                ('custom_product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='images', to='products.customproduct')),
            ],
        ),
        migrations.CreateModel(
            name='CustomProductVideo',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('video', models.FileField(upload_to='custom_product_videos/')),
                ('created_date', models.DateTimeField(auto_now_add=True)),
                ('custom_product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='videos', to='products.customproduct')),
            ],
        ),
        migrations.CreateModel(
            name='Products',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('product_type', models.CharField(choices=[('Master Product', 'Master Product'), ('Custom Product', 'Custom Product')], max_length=100)),
                ('item_name', models.CharField(max_length=120)),
                ('item_code', models.CharField(max_length=120)),
                ('item_description', models.TextField(max_length=1300)),
                ('veg_or_non_veg_status', models.CharField(choices=[('Veg', 'Veg'), ('Non Veg', 'Non Veg')], max_length=100)),
                ('i_gst', models.FloatField(blank=True, max_length=20, null=True)),
                ('s_gst', models.FloatField(blank=True, max_length=20, null=True)),
                ('c_gst', models.FloatField(blank=True, max_length=20, null=True)),
                ('cess', models.FloatField(blank=True, max_length=20, null=True)),
                ('created_date', models.DateTimeField(auto_now_add=True, null=True)),
                ('updated_date', models.DateTimeField(auto_now=True, null=True)),
                ('item_category', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='products.productcategory')),
            ],
        ),
        migrations.CreateModel(
            name='ProductReview',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('rating', models.PositiveIntegerField(choices=[(1, '1 Star'), (2, '2 Stars'), (3, '3 Stars'), (4, '4 Stars'), (5, '5 Stars')])),
                ('review_heading', models.CharField(max_length=150)),
                ('review_text', models.TextField()),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
                ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='reviews', to='products.products')),
            ],
            options={
                'ordering': ['-created_at'],
            },
        ),
        migrations.CreateModel(
            name='ProductImage',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('image', models.ImageField(upload_to='product_images/')),
                ('created_date', models.DateTimeField(auto_now_add=True)),
                ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='images', to='products.products')),
            ],
        ),
        migrations.CreateModel(
            name='DynamicFiltering',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('filter_name', models.CharField(max_length=35)),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('products', models.ManyToManyField(to='products.products')),
            ],
        ),
        migrations.CreateModel(
            name='ProductSubCategory',
            fields=[
                ('uuid', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False, unique=True)),
                ('sub_category_name', models.CharField(max_length=100)),
                ('sub_category_code', models.CharField(max_length=200, unique=True)),
                ('standard_image', models.ImageField(blank=True, null=True, upload_to='standard_images/')),
                ('created_at', models.DateTimeField(auto_now_add=True, null=True)),
                ('updated_date', models.DateTimeField(auto_now=True, null=True)),
                ('category', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='products.productcategory')),
            ],
        ),
        migrations.AddField(
            model_name='products',
            name='item_sub_category',
            field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='products.productsubcategory'),
        ),
        migrations.CreateModel(
            name='ProductVideo',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('video', models.FileField(upload_to='product_videos/')),
                ('created_date', models.DateTimeField(auto_now_add=True)),
                ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='videos', to='products.products')),
            ],
        ),
        migrations.CreateModel(
            name='SKU',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('sku_name', models.CharField(max_length=120)),
                ('sku_code', models.CharField(max_length=120)),
                ('sku_quantity', models.PositiveIntegerField()),
                ('sku_unit', models.CharField(max_length=20)),
                ('sku_mrp', models.FloatField(blank=True, max_length=20, null=True)),
                ('sku_expiry_duration', models.PositiveIntegerField()),
                ('sku_bulk_qty_limit', models.PositiveIntegerField()),
                ('sku_status', models.CharField(choices=[('Visible', 'Visible'), ('Disabled', 'Disabled'), ('Out of Stock', 'Out of Stock')], max_length=100)),
                ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='skus', to='products.products')),
            ],
        ),
        migrations.CreateModel(
            name='SalesUnitProductSelection',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('shop_admin_status', models.CharField(choices=[('Visible', 'Visible'), ('Disabled', 'Disabled'), ('Out of Stock', 'Out of Stock')], default='Disabled', max_length=100)),
                ('status', models.CharField(choices=[('Visible', 'Visible'), ('Disabled', 'Disabled'), ('Out of Stock', 'Out of Stock')], max_length=100)),
                ('sales_unit', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='shops.shop')),
                ('sku', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='products.sku')),
            ],
        ),
        migrations.CreateModel(
            name='SpecialList',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('special_name', models.CharField(max_length=35)),
                ('icon', models.ImageField(blank=True, null=True, upload_to='icons/')),
                ('standard_image', models.ImageField(blank=True, null=True, upload_to='standard_images/')),
                ('banner_image', models.ImageField(blank=True, null=True, upload_to='banners/')),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('products', models.ManyToManyField(to='products.products')),
            ],
        ),
        migrations.CreateModel(
            name='Tags',
            fields=[
                ('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
                ('tag_name', models.CharField(max_length=35)),
                ('icon', models.ImageField(blank=True, null=True, upload_to='icons/')),
                ('created_at', models.DateTimeField(auto_now_add=True)),
                ('products', models.ManyToManyField(to='products.products')),
            ],
        ),
        migrations.CreateModel(
            name='Wishlist',
            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, null=True)),
                ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='products.products')),
                ('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
            ],
            options={
                'unique_together': {('user', 'product')},
            },
        ),
    ]
