# Generated by Django 3.0.13 on 2021-02-23 23:00 import cms.models.fields from django.conf import settings import django.core.validators from django.db import migrations, models import django.db.models.deletion import django.db.models.manager import django.utils.timezone import django_fsm import djangocms_text_ckeditor.fields import filer.fields.image import shop.models.address import shop.models.fields import shop.models.product import shop.money.fields import shop.payment.workflows import shop.shipping.workflows import shop_stripe.workflows class Migration(migrations.Migration): initial = True dependencies = [ migrations.swappable_dependency(settings.FILER_IMAGE_MODEL), ('cms', '0022_auto_20180620_1551'), ('email_auth', '0005_auto_20191123_2051'), ('contenttypes', '0002_remove_content_type_name'), ] operations = [ migrations.CreateModel( name='BillingAddress', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('priority', models.SmallIntegerField(db_index=True, default=0, help_text='Priority for using this address')), ('name', models.CharField(max_length=1024, verbose_name='Full name')), ('address1', models.CharField(max_length=1024, verbose_name='Address line 1')), ('address2', models.CharField(blank=True, max_length=1024, null=True, verbose_name='Address line 2')), ('zip_code', models.CharField(max_length=12, verbose_name='ZIP / Postal code')), ('city', models.CharField(max_length=1024, verbose_name='City')), ('country', shop.models.address.CountryField(verbose_name='Country')), ], options={ 'verbose_name': 'Billing Address', 'verbose_name_plural': 'Billing Addresses', }, ), migrations.CreateModel( name='Cart', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created at')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated at')), ('extra', shop.models.fields.JSONField(verbose_name='Arbitrary information for this cart')), ('billing_address', models.ForeignKey(default=None, null=True, on_delete=django.db.models.deletion.SET_DEFAULT, related_name='+', to='weirdlittleempire.BillingAddress')), ], ), migrations.CreateModel( name='Customer', fields=[ ('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, primary_key=True, related_name='customer', serialize=False, to=settings.AUTH_USER_MODEL)), ('recognized', shop.models.fields.ChoiceEnumField(help_text='Designates the state the customer is recognized as.', verbose_name='Recognized as')), ('last_access', models.DateTimeField(default=django.utils.timezone.now, verbose_name='Last accessed')), ('extra', shop.models.fields.JSONField(editable=False, verbose_name='Extra information about this customer')), ('number', models.PositiveIntegerField(default=None, null=True, unique=True, verbose_name='Customer Number')), ('salutation', models.CharField(choices=[('mrs', 'Mrs.'), ('mr', 'Mr.'), ('na', '(n/a)')], max_length=5, verbose_name='Salutation')), ], ), migrations.CreateModel( name='Delivery', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('shipping_id', models.CharField(blank=True, help_text="The transaction processor's reference", max_length=255, null=True, verbose_name='Shipping ID')), ('fulfilled_at', models.DateTimeField(blank=True, help_text='Timestamp of delivery fulfillment', null=True, verbose_name='Fulfilled at')), ('shipped_at', models.DateTimeField(blank=True, help_text='Timestamp of delivery shipment', null=True, verbose_name='Shipped at')), ('shipping_method', models.CharField(help_text='The shipping backend used to deliver items of this order', max_length=50, verbose_name='Shipping method')), ], options={ 'verbose_name': 'Delivery', 'verbose_name_plural': 'Deliveries', 'get_latest_by': 'shipped_at', 'abstract': False, }, ), migrations.CreateModel( name='Manufacturer', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('name', models.CharField(max_length=50, unique=True, verbose_name='Name')), ], ), migrations.CreateModel( name='OperatingSystem', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('name', models.CharField(max_length=50, unique=True, verbose_name='Name')), ], ), migrations.CreateModel( name='Order', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('status', django_fsm.FSMField(default='new', max_length=50, protected=True, verbose_name='Status')), ('currency', models.CharField(editable=False, help_text='Currency in which this order was concluded', max_length=7)), ('_subtotal', models.DecimalField(decimal_places=2, max_digits=30, verbose_name='Subtotal')), ('_total', models.DecimalField(decimal_places=2, max_digits=30, verbose_name='Total')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created at')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated at')), ('extra', shop.models.fields.JSONField(help_text='Arbitrary information for this order object on the moment of purchase.', verbose_name='Extra fields')), ('stored_request', shop.models.fields.JSONField(help_text='Parts of the Request objects on the moment of purchase.')), ('number', models.PositiveIntegerField(default=None, null=True, unique=True, verbose_name='Order Number')), ('shipping_address_text', models.TextField(blank=True, help_text='Shipping address at the moment of purchase.', null=True, verbose_name='Shipping Address')), ('billing_address_text', models.TextField(blank=True, help_text='Billing address at the moment of purchase.', null=True, verbose_name='Billing Address')), ('token', models.CharField(editable=False, help_text='Secret key to verify ownership on detail view without requiring authentication.', max_length=40, null=True, verbose_name='Token')), ('customer', models.ForeignKey(on_delete=django.db.models.deletion.PROTECT, related_name='orders', to='weirdlittleempire.Customer', verbose_name='Customer')), ], options={ 'verbose_name': 'Order', 'verbose_name_plural': 'Orders', }, bases=(shop.payment.workflows.ManualPaymentWorkflowMixin, shop.payment.workflows.CancelOrderWorkflowMixin, shop.shipping.workflows.PartialDeliveryWorkflowMixin, shop_stripe.workflows.OrderWorkflowMixin, models.Model), ), migrations.CreateModel( name='Product', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created at')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated at')), ('active', models.BooleanField(default=True, help_text='Is this product publicly visible.', verbose_name='Active')), ('product_name', models.CharField(max_length=255, verbose_name='Product Name')), ('slug', models.SlugField(unique=True, verbose_name='Slug')), ('caption', djangocms_text_ckeditor.fields.HTMLField(blank=True, help_text="Short description used in the catalog's list view of products.", null=True, verbose_name='Caption')), ('order', models.PositiveIntegerField(db_index=True, verbose_name='Sort by')), ], options={ 'verbose_name': 'Product', 'verbose_name_plural': 'Products', 'ordering': ('order',), }, bases=(shop.models.product.CMSPageReferenceMixin, models.Model), ), migrations.CreateModel( name='SmartCard', fields=[ ('product_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='weirdlittleempire.Product')), ('unit_price', shop.money.fields.MoneyField(decimal_places=3, help_text='Net price for this product', verbose_name='Unit price')), ('card_type', models.CharField(choices=[('SD', 'SD'), ('micro SD', 'micro SD'), ('SDXC', 'SDXC'), ('micro SDXC', 'micro SDXC'), ('SDHC', 'SDHC'), ('micro SDHC', 'micro SDHC'), ('SDHC II', 'SDHC II'), ('micro SDHC II', 'micro SDHC II')], max_length=15, verbose_name='Card Type')), ('speed', models.CharField(choices=[('4', '4 MB/s'), ('20', '20 MB/s'), ('30', '30 MB/s'), ('40', '40 MB/s'), ('48', '48 MB/s'), ('80', '80 MB/s'), ('95', '95 MB/s'), ('280', '280 MB/s')], max_length=8, verbose_name='Transfer Speed')), ('product_code', models.CharField(max_length=255, unique=True, verbose_name='Product code')), ('storage', models.PositiveIntegerField(help_text='Storage capacity in GB', verbose_name='Storage Capacity')), ('description', djangocms_text_ckeditor.fields.HTMLField(help_text='Long description for the detail view of this product.', verbose_name='Description')), ('quantity', models.PositiveIntegerField(default=0, help_text='Available quantity in stock', validators=[django.core.validators.MinValueValidator(0)], verbose_name='Quantity')), ], options={ 'verbose_name': 'Smart Card', 'verbose_name_plural': 'Smart Cards', 'ordering': ['order'], }, bases=(shop.models.product.AvailableProductMixin, 'weirdlittleempire.product'), managers=[ ('default_manager', django.db.models.manager.Manager()), ('objects', django.db.models.manager.Manager()), ], ), migrations.CreateModel( name='SmartPhoneModel', fields=[ ('product_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='weirdlittleempire.Product')), ('battery_type', models.PositiveSmallIntegerField(choices=[(1, 'Lithium Polymer (Li-Poly)'), (2, 'Lithium Ion (Li-Ion)')], verbose_name='Battery type')), ('battery_capacity', models.PositiveIntegerField(help_text='Battery capacity in mAh', verbose_name='Capacity')), ('ram_storage', models.PositiveIntegerField(help_text='RAM storage in MB', verbose_name='RAM')), ('wifi_connectivity', models.PositiveIntegerField(choices=[(1, '802.11 b/g/n')], help_text='WiFi Connectivity', verbose_name='WiFi')), ('bluetooth', models.PositiveIntegerField(choices=[(1, 'Bluetooth 4.0'), (2, 'Bluetooth 3.0'), (3, 'Bluetooth 2.1')], help_text='Bluetooth Connectivity', verbose_name='Bluetooth')), ('gps', models.BooleanField(default=False, help_text='GPS integrated', verbose_name='GPS')), ('width', models.DecimalField(decimal_places=1, help_text='Width in mm', max_digits=4, verbose_name='Width')), ('height', models.DecimalField(decimal_places=1, help_text='Height in mm', max_digits=4, verbose_name='Height')), ('weight', models.DecimalField(decimal_places=1, help_text='Weight in gram', max_digits=5, verbose_name='Weight')), ('screen_size', models.DecimalField(decimal_places=2, help_text='Diagonal screen size in inch', max_digits=4, verbose_name='Screen size')), ('description', djangocms_text_ckeditor.fields.HTMLField(help_text="Full description used in the catalog's detail view of Smart Phones.", verbose_name='Description')), ('operating_system', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.OperatingSystem', verbose_name='Operating System')), ], options={ 'verbose_name': 'Smart Phone', 'verbose_name_plural': 'Smart Phones', }, bases=('weirdlittleempire.product',), managers=[ ('default_manager', django.db.models.manager.Manager()), ('objects', django.db.models.manager.Manager()), ], ), migrations.CreateModel( name='ShippingAddress', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('priority', models.SmallIntegerField(db_index=True, default=0, help_text='Priority for using this address')), ('name', models.CharField(max_length=1024, verbose_name='Full name')), ('address1', models.CharField(max_length=1024, verbose_name='Address line 1')), ('address2', models.CharField(blank=True, max_length=1024, null=True, verbose_name='Address line 2')), ('zip_code', models.CharField(max_length=12, verbose_name='ZIP / Postal code')), ('city', models.CharField(max_length=1024, verbose_name='City')), ('country', shop.models.address.CountryField(verbose_name='Country')), ('customer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Customer')), ], options={ 'verbose_name': 'Shipping Address', 'verbose_name_plural': 'Shipping Addresses', }, ), migrations.CreateModel( name='ProductPage', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('page', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='cms.Page')), ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Product')), ], options={ 'verbose_name': 'Category', 'verbose_name_plural': 'Categories', 'abstract': False, 'unique_together': {('page', 'product')}, }, ), migrations.CreateModel( name='ProductImage', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('order', models.SmallIntegerField(default=0)), ('image', filer.fields.image.FilerImageField(on_delete=django.db.models.deletion.CASCADE, to=settings.FILER_IMAGE_MODEL)), ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Product')), ], options={ 'verbose_name': 'Product Image', 'verbose_name_plural': 'Product Images', 'ordering': ['order'], 'abstract': False, }, ), migrations.AddField( model_name='product', name='cms_pages', field=models.ManyToManyField(help_text='Choose list view this product shall appear on.', through='weirdlittleempire.ProductPage', to='cms.Page'), ), migrations.AddField( model_name='product', name='images', field=models.ManyToManyField(through='weirdlittleempire.ProductImage', to=settings.FILER_IMAGE_MODEL), ), migrations.AddField( model_name='product', name='manufacturer', field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Manufacturer', verbose_name='Manufacturer'), ), migrations.AddField( model_name='product', name='polymorphic_ctype', field=models.ForeignKey(editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='polymorphic_weirdlittleempire.product_set+', to='contenttypes.ContentType'), ), migrations.CreateModel( name='OrderPayment', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('amount', shop.money.fields.MoneyField(help_text='How much was paid with this particular transfer.', verbose_name='Amount paid')), ('transaction_id', models.CharField(help_text="The transaction processor's reference", max_length=255, verbose_name='Transaction ID')), ('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Received at')), ('payment_method', models.CharField(help_text='The payment backend used to process the purchase', max_length=50, verbose_name='Payment method')), ('order', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Order', verbose_name='Order')), ], options={ 'verbose_name': 'Order payment', 'verbose_name_plural': 'Order payments', }, ), migrations.CreateModel( name='OrderItem', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('product_name', models.CharField(blank=True, help_text='Product name at the moment of purchase.', max_length=255, null=True, verbose_name='Product name')), ('product_code', models.CharField(blank=True, help_text='Product code at the moment of purchase.', max_length=255, null=True, verbose_name='Product code')), ('_unit_price', models.DecimalField(decimal_places=2, help_text='Products unit price at the moment of purchase.', max_digits=30, null=True, verbose_name='Unit price')), ('_line_total', models.DecimalField(decimal_places=2, help_text='Line total on the invoice at the moment of purchase.', max_digits=30, null=True, verbose_name='Line Total')), ('extra', shop.models.fields.JSONField(help_text='Arbitrary information for this order item', verbose_name='Extra fields')), ('quantity', models.PositiveIntegerField(verbose_name='Ordered quantity')), ('canceled', models.BooleanField(default=False, verbose_name='Item canceled ')), ('order', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='items', to='weirdlittleempire.Order', verbose_name='Order')), ('product', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='weirdlittleempire.Product', verbose_name='Product')), ], ), migrations.CreateModel( name='DeliveryItem', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('quantity', models.IntegerField(default=0, verbose_name='Delivered quantity')), ('delivery', models.ForeignKey(help_text='Refer to the shipping provider used to ship this item', on_delete=django.db.models.deletion.CASCADE, related_name='items', to='weirdlittleempire.Delivery', verbose_name='Delivery')), ('item', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='deliver_item', to='weirdlittleempire.OrderItem', verbose_name='Ordered item')), ], ), migrations.AddField( model_name='delivery', name='order', field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Order'), ), migrations.CreateModel( name='CartItem', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('product_code', models.CharField(blank=True, help_text='Product code of added item.', max_length=255, null=True, verbose_name='Product code')), ('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated at')), ('extra', shop.models.fields.JSONField(verbose_name='Arbitrary information for this cart item')), ('quantity', models.PositiveIntegerField()), ('cart', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='items', to='weirdlittleempire.Cart')), ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Product')), ], ), migrations.AddField( model_name='cart', name='customer', field=models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='cart', to='weirdlittleempire.Customer', verbose_name='Customer'), ), migrations.AddField( model_name='cart', name='shipping_address', field=models.ForeignKey(default=None, null=True, on_delete=django.db.models.deletion.SET_DEFAULT, related_name='+', to='weirdlittleempire.ShippingAddress'), ), migrations.AddField( model_name='billingaddress', name='customer', field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='weirdlittleempire.Customer'), ), migrations.CreateModel( name='SmartPhoneVariant', fields=[ ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), ('product_code', models.CharField(max_length=255, unique=True, verbose_name='Product code')), ('unit_price', shop.money.fields.MoneyField(decimal_places=3, help_text='Net price for this product', verbose_name='Unit price')), ('storage', models.PositiveIntegerField(help_text='Internal storage in GB', verbose_name='Internal Storage')), ('quantity', models.PositiveIntegerField(default=0, help_text='Available quantity in stock', validators=[django.core.validators.MinValueValidator(0)], verbose_name='Quantity')), ('product', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='variants', to='weirdlittleempire.SmartPhoneModel', verbose_name='Smartphone Model')), ], bases=(shop.models.product.AvailableProductMixin, models.Model), ), migrations.AlterUniqueTogether( name='delivery', unique_together={('shipping_method', 'shipping_id')}, ), migrations.CreateModel( name='Commodity', fields=[ ('product_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='weirdlittleempire.Product')), ('unit_price', shop.money.fields.MoneyField(decimal_places=3, help_text='Net price for this product', verbose_name='Unit price')), ('product_code', models.CharField(max_length=255, unique=True, verbose_name='Product code')), ('quantity', models.PositiveIntegerField(default=0, help_text='Available quantity in stock', validators=[django.core.validators.MinValueValidator(0)], verbose_name='Quantity')), ('placeholder', cms.models.fields.PlaceholderField(editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, slotname='Commodity Details', to='cms.Placeholder')), ], options={ 'verbose_name': 'Commodity', 'verbose_name_plural': 'Commodities', }, bases=(shop.models.product.AvailableProductMixin, 'weirdlittleempire.product'), managers=[ ('default_manager', django.db.models.manager.Manager()), ('objects', django.db.models.manager.Manager()), ], ), ]