update
This commit is contained in:
parent
0f9b2cff5f
commit
047436c782
@ -1,4 +1,4 @@
|
|||||||
# Generated by Django 5.1.4 on 2024-12-26 16:17
|
# Generated by Django 5.1.4 on 2025-01-06 13:50
|
||||||
|
|
||||||
from django.db import migrations, models
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
@ -1,4 +1,4 @@
|
|||||||
# Generated by Django 4.2.17 on 2025-01-02 08:05
|
# Generated by Django 5.1.4 on 2025-01-06 13:50
|
||||||
|
|
||||||
from django.db import migrations, models
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
# Generated by Django 4.2.17 on 2025-01-02 08:05
|
# Generated by Django 5.1.4 on 2025-01-06 13:50
|
||||||
|
|
||||||
from django.db import migrations, models
|
|
||||||
import django.db.models.deletion
|
import django.db.models.deletion
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
class Migration(migrations.Migration):
|
class Migration(migrations.Migration):
|
||||||
|
|||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
@ -1,12 +1,12 @@
|
|||||||
# Generated by Django 4.2.17 on 2025-01-02 08:05
|
# Generated by Django 5.1.4 on 2025-01-06 13:50
|
||||||
|
|
||||||
from decimal import Decimal
|
|
||||||
from django.conf import settings
|
|
||||||
from django.db import migrations, models
|
|
||||||
import django.db.models.deletion
|
import django.db.models.deletion
|
||||||
import inventory.mixins
|
import inventory.mixins
|
||||||
import inventory.models
|
import inventory.models
|
||||||
import phonenumber_field.modelfields
|
import phonenumber_field.modelfields
|
||||||
|
from decimal import Decimal
|
||||||
|
from django.conf import settings
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
class Migration(migrations.Migration):
|
class Migration(migrations.Migration):
|
||||||
@ -50,91 +50,6 @@ class Migration(migrations.Migration):
|
|||||||
},
|
},
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
|
||||||
name='CarModel',
|
|
||||||
fields=[
|
|
||||||
('id_car_model', models.AutoField(primary_key=True, serialize=False)),
|
|
||||||
('name', models.CharField(max_length=255)),
|
|
||||||
('arabic_name', models.CharField(max_length=255)),
|
|
||||||
('id_car_make', models.ForeignKey(db_column='id_car_make', on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmake')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Model',
|
|
||||||
},
|
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='CarSerie',
|
|
||||||
fields=[
|
|
||||||
('id_car_serie', models.AutoField(primary_key=True, serialize=False)),
|
|
||||||
('name', models.CharField(max_length=255)),
|
|
||||||
('arabic_name', models.CharField(max_length=255)),
|
|
||||||
('year_begin', models.IntegerField(blank=True, null=True)),
|
|
||||||
('year_end', models.IntegerField(blank=True, null=True)),
|
|
||||||
('id_car_model', models.ForeignKey(db_column='id_car_model', on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmodel')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Series',
|
|
||||||
},
|
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='CarSpecification',
|
|
||||||
fields=[
|
|
||||||
('id_car_specification', models.AutoField(primary_key=True, serialize=False)),
|
|
||||||
('name', models.CharField(max_length=255)),
|
|
||||||
('arabic_name', models.CharField(max_length=255)),
|
|
||||||
('id_parent', models.ForeignKey(blank=True, db_column='id_parent', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carspecification')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Specification',
|
|
||||||
},
|
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Customer',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('first_name', models.CharField(max_length=50, verbose_name='First Name')),
|
|
||||||
('middle_name', models.CharField(blank=True, max_length=50, null=True, verbose_name='Middle Name')),
|
|
||||||
('last_name', models.CharField(max_length=50, verbose_name='Last Name')),
|
|
||||||
('email', models.EmailField(max_length=254, unique=True, verbose_name='Email')),
|
|
||||||
('national_id', models.CharField(max_length=10, unique=True, verbose_name='National ID')),
|
|
||||||
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', unique=True, verbose_name='Phone Number')),
|
|
||||||
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
|
||||||
('created', models.DateTimeField(auto_now_add=True, verbose_name='Created')),
|
|
||||||
('is_lead', models.BooleanField(default=False, verbose_name='Is Lead')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Customer',
|
|
||||||
'verbose_name_plural': 'Customers',
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Dealer',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('crn', models.CharField(blank=True, max_length=10, null=True, verbose_name='Commercial Registration Number')),
|
|
||||||
('vrn', models.CharField(blank=True, max_length=15, null=True, verbose_name='VAT Registration Number')),
|
|
||||||
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
|
||||||
('name', models.CharField(max_length=255, verbose_name='English Name')),
|
|
||||||
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
|
||||||
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
|
||||||
('logo', models.ImageField(blank=True, null=True, upload_to='logos/users', verbose_name='Logo')),
|
|
||||||
('joined_at', models.DateTimeField(auto_now_add=True, verbose_name='Joined At')),
|
|
||||||
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
|
||||||
('entity', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='django_ledger.entitymodel')),
|
|
||||||
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='dealer', to=settings.AUTH_USER_MODEL)),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Dealer',
|
|
||||||
'verbose_name_plural': 'Dealers',
|
|
||||||
},
|
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
|
||||||
managers=[
|
|
||||||
('objects', inventory.models.DealerUserManager()),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='ExteriorColors',
|
name='ExteriorColors',
|
||||||
fields=[
|
fields=[
|
||||||
@ -163,44 +78,6 @@ class Migration(migrations.Migration):
|
|||||||
},
|
},
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
|
||||||
name='Opportunity',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('deal_name', models.CharField(max_length=255, verbose_name='Deal Name')),
|
|
||||||
('deal_value', models.DecimalField(decimal_places=2, max_digits=10, verbose_name='Deal Value')),
|
|
||||||
('deal_status', models.CharField(choices=[('new', 'New'), ('pending', 'Pending'), ('canceled', 'Canceled'), ('completed', 'Completed')], default='new', max_length=50, verbose_name='Deal Status')),
|
|
||||||
('priority', models.CharField(choices=[('low', 'Low'), ('medium', 'Medium'), ('high', 'High')], default='low', max_length=50, verbose_name='Priority')),
|
|
||||||
('source', models.CharField(choices=[('referrals', 'Referrals'), ('walk_in', 'Walk In'), ('toll_free', 'Toll Free'), ('whatsapp', 'Whatsapp'), ('showrooms', 'Showrooms'), ('website', 'Website'), ('other', 'Other')], default='showrooms', max_length=255, verbose_name='Source')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
|
||||||
('car', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='inventory.car', verbose_name='Car')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Opportunity',
|
|
||||||
'verbose_name_plural': 'Opportunities',
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Organization',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('name', models.CharField(max_length=255, verbose_name='Name')),
|
|
||||||
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
|
||||||
('crn', models.CharField(max_length=15, verbose_name='Commercial Registration Number')),
|
|
||||||
('vrn', models.CharField(max_length=15, verbose_name='VAT Registration Number')),
|
|
||||||
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
|
||||||
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
|
||||||
('logo', models.ImageField(blank=True, null=True, upload_to='logos', verbose_name='Logo')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='organizations', to='inventory.dealer')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Organization',
|
|
||||||
'verbose_name_plural': 'Organizations',
|
|
||||||
},
|
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='Payment',
|
name='Payment',
|
||||||
fields=[
|
fields=[
|
||||||
@ -215,50 +92,24 @@ class Migration(migrations.Migration):
|
|||||||
'verbose_name_plural': 'payments',
|
'verbose_name_plural': 'payments',
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
|
||||||
name='SaleQuotation',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('quotation_number', models.CharField(max_length=10, unique=True)),
|
|
||||||
('amount', models.DecimalField(decimal_places=2, default=Decimal('0.00'), max_digits=10, verbose_name='Amount')),
|
|
||||||
('remarks', models.TextField(blank=True, null=True, verbose_name='Remarks')),
|
|
||||||
('is_approved', models.BooleanField(default=False)),
|
|
||||||
('status', models.CharField(choices=[('Draft', 'Draft'), ('Approved', 'Approved'), ('In Review', 'In Review'), ('Paid', 'Paid')], default='Draft', max_length=10, verbose_name='Status')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
|
||||||
('posted', models.BooleanField(default=False)),
|
|
||||||
('payment_id', models.CharField(blank=True, max_length=255, null=True, verbose_name='Payment ID')),
|
|
||||||
('is_paid', models.BooleanField(default=False)),
|
|
||||||
('date_draft', models.DateTimeField(blank=True, null=True, verbose_name='Draft Date')),
|
|
||||||
('date_in_review', models.DateTimeField(blank=True, null=True, verbose_name='In Review Date')),
|
|
||||||
('date_approved', models.DateTimeField(blank=True, null=True, verbose_name='Approved Date')),
|
|
||||||
('date_paid', models.DateTimeField(blank=True, null=True, verbose_name='Paid Date')),
|
|
||||||
('date_void', models.DateTimeField(blank=True, null=True, verbose_name='Void Date')),
|
|
||||||
('date_canceled', models.DateTimeField(blank=True, null=True, verbose_name='Canceled Date')),
|
|
||||||
('customer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='quotations', to='inventory.customer', verbose_name='Customer')),
|
|
||||||
('dealer', models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='sales', to='inventory.dealer')),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Subscription',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('plan', models.CharField(max_length=255)),
|
|
||||||
('start_date', models.DateField()),
|
|
||||||
('end_date', models.DateField()),
|
|
||||||
('max_users', models.IntegerField()),
|
|
||||||
('is_active', models.BooleanField(default=True)),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='SubscriptionPlan',
|
name='SubscriptionPlan',
|
||||||
fields=[
|
fields=[
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
('name', models.CharField(max_length=255)),
|
('name', models.CharField(help_text='Name of the subscription plan', max_length=100, unique=True)),
|
||||||
('description', models.TextField()),
|
('description', models.TextField()),
|
||||||
('price', models.DecimalField(decimal_places=2, max_digits=10)),
|
('price', models.DecimalField(decimal_places=2, max_digits=10)),
|
||||||
('max_users', models.IntegerField()),
|
('max_users', models.PositiveIntegerField(default=1, help_text='Maximum number of users allowed')),
|
||||||
|
('max_inventory_size', models.PositiveIntegerField(default=50, help_text='Maximum number of cars in inventory')),
|
||||||
|
('support_level', models.CharField(choices=[('basic', 'Basic Support'), ('priority', 'Priority Support'), ('dedicated', 'Dedicated Support')], default='basic', help_text='Level of support provided', max_length=50)),
|
||||||
|
('custom_features', models.JSONField(blank=True, help_text='Additional features specific to this plan', null=True)),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True)),
|
||||||
],
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Subscription Plan',
|
||||||
|
'verbose_name_plural': 'Subscription Plans',
|
||||||
|
},
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='VatRate',
|
name='VatRate',
|
||||||
@ -270,206 +121,92 @@ class Migration(migrations.Migration):
|
|||||||
],
|
],
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='Vendor',
|
name='CarFinance',
|
||||||
fields=[
|
fields=[
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
('crn', models.CharField(max_length=10, unique=True, verbose_name='Commercial Registration Number')),
|
('cost_price', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Cost Price')),
|
||||||
('vrn', models.CharField(max_length=15, unique=True, verbose_name='VAT Registration Number')),
|
('selling_price', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Selling Price')),
|
||||||
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
('discount_amount', models.DecimalField(decimal_places=2, default=Decimal('0.00'), max_digits=14, verbose_name='Discount Amount')),
|
||||||
('name', models.CharField(max_length=255, verbose_name='English Name')),
|
('additional_services', models.ManyToManyField(blank=True, related_name='additional_finances', to='django_ledger.itemmodel')),
|
||||||
('contact_person', models.CharField(max_length=100, verbose_name='Contact Person')),
|
('car', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='finances', to='inventory.car')),
|
||||||
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
|
||||||
('email', models.EmailField(max_length=255, verbose_name='Email Address')),
|
|
||||||
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
|
||||||
('logo', models.ImageField(blank=True, null=True, upload_to='logos/vendors', verbose_name='Logo')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='vendors', to='inventory.dealer')),
|
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
'verbose_name': 'Vendor',
|
'verbose_name': 'Car Financial Details',
|
||||||
'verbose_name_plural': 'Vendors',
|
'verbose_name_plural': 'Car Financial Details',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='car',
|
||||||
|
name='id_car_make',
|
||||||
|
field=models.ForeignKey(blank=True, db_column='id_car_make', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmake', verbose_name='Make'),
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='CarModel',
|
||||||
|
fields=[
|
||||||
|
('id_car_model', models.AutoField(primary_key=True, serialize=False)),
|
||||||
|
('name', models.CharField(max_length=255)),
|
||||||
|
('arabic_name', models.CharField(max_length=255)),
|
||||||
|
('id_car_make', models.ForeignKey(db_column='id_car_make', on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmake')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Model',
|
||||||
},
|
},
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
),
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='car',
|
||||||
|
name='id_car_model',
|
||||||
|
field=models.ForeignKey(blank=True, db_column='id_car_model', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmodel', verbose_name='Model'),
|
||||||
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='UserActivityLog',
|
name='CarRegistration',
|
||||||
fields=[
|
fields=[
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
('action', models.TextField()),
|
('plate_number', models.IntegerField(verbose_name='Plate Number')),
|
||||||
('timestamp', models.DateTimeField(auto_now_add=True)),
|
('text1', models.CharField(max_length=1, verbose_name='Text 1')),
|
||||||
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
('text2', models.CharField(max_length=1, verbose_name='Text 2')),
|
||||||
|
('text3', models.CharField(max_length=1, verbose_name='Text 3')),
|
||||||
|
('registration_date', models.DateTimeField(verbose_name='Registration Date')),
|
||||||
|
('car', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='registrations', to='inventory.car', verbose_name='Car')),
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
'verbose_name': 'User Activity Log',
|
'verbose_name': 'Registration',
|
||||||
'verbose_name_plural': 'User Activity Logs',
|
'verbose_name_plural': 'Registrations',
|
||||||
'ordering': ['-timestamp'],
|
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='SubscriptionUser',
|
name='CarSerie',
|
||||||
fields=[
|
fields=[
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
('id_car_serie', models.AutoField(primary_key=True, serialize=False)),
|
||||||
('subscription', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='inventory.subscription')),
|
('name', models.CharField(max_length=255)),
|
||||||
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
('arabic_name', models.CharField(max_length=255)),
|
||||||
],
|
('year_begin', models.IntegerField(blank=True, null=True)),
|
||||||
),
|
('year_end', models.IntegerField(blank=True, null=True)),
|
||||||
migrations.AddField(
|
('id_car_model', models.ForeignKey(db_column='id_car_model', on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmodel')),
|
||||||
model_name='subscription',
|
|
||||||
name='users',
|
|
||||||
field=models.ManyToManyField(through='inventory.SubscriptionUser', to=settings.AUTH_USER_MODEL),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Staff',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('name', models.CharField(max_length=255, verbose_name='Name')),
|
|
||||||
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
|
||||||
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
|
||||||
('staff_type', models.CharField(choices=[('manager', 'Manager'), ('inventory', 'Inventory'), ('accountant', 'Accountant'), ('sales', 'Sales')], max_length=255, verbose_name='Staff Type')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
|
||||||
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='staff', to='inventory.dealer')),
|
|
||||||
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='staff', to=settings.AUTH_USER_MODEL)),
|
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
'verbose_name': 'Staff',
|
'verbose_name': 'Series',
|
||||||
'verbose_name_plural': 'Staff',
|
|
||||||
'permissions': [],
|
|
||||||
},
|
},
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
migrations.AddField(
|
||||||
name='SalesOrder',
|
model_name='car',
|
||||||
fields=[
|
name='id_car_serie',
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
field=models.ForeignKey(blank=True, db_column='id_car_serie', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carserie', verbose_name='Series'),
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('total_amount', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Total Amount')),
|
|
||||||
('quotation', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='sales_order', to='inventory.salequotation', verbose_name='Quotation')),
|
|
||||||
],
|
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='SaleQuotationCar',
|
name='CarSpecification',
|
||||||
fields=[
|
fields=[
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
('id_car_specification', models.AutoField(primary_key=True, serialize=False)),
|
||||||
('quantity', models.PositiveIntegerField(default=1, verbose_name='Quantity')),
|
('name', models.CharField(max_length=255)),
|
||||||
('car', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='inventory.car', verbose_name='Car')),
|
('arabic_name', models.CharField(max_length=255)),
|
||||||
('quotation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='quotation_cars', to='inventory.salequotation', verbose_name='Quotation')),
|
('id_parent', models.ForeignKey(blank=True, db_column='id_parent', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carspecification')),
|
||||||
],
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Representative',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('name', models.CharField(max_length=255, verbose_name='Name')),
|
|
||||||
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
|
||||||
('id_number', models.CharField(max_length=10, verbose_name='ID Number')),
|
|
||||||
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
|
||||||
('email', models.EmailField(max_length=255, verbose_name='Email Address')),
|
|
||||||
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
|
||||||
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='representatives', to='inventory.dealer')),
|
|
||||||
('organization', models.ManyToManyField(related_name='representatives', to='inventory.organization')),
|
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
'verbose_name': 'Representative',
|
'verbose_name': 'Specification',
|
||||||
'verbose_name_plural': 'Representatives',
|
|
||||||
},
|
},
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
|
||||||
name='Refund',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('amount', models.DecimalField(decimal_places=2, max_digits=10, verbose_name='amount')),
|
|
||||||
('reason', models.TextField(blank=True, verbose_name='reason')),
|
|
||||||
('refund_date', models.DateField(auto_now_add=True, verbose_name='refund date')),
|
|
||||||
('payment', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='refund', to='inventory.payment')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'refund',
|
|
||||||
'verbose_name_plural': 'refunds',
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='payment',
|
|
||||||
name='quotation',
|
|
||||||
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='payments', to='inventory.salequotation'),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='OpportunityLog',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('action', models.CharField(choices=[('create', 'Create'), ('update', 'Update'), ('delete', 'Delete'), ('status_change', 'Status Change')], max_length=50, verbose_name='Action')),
|
|
||||||
('old_status', models.CharField(blank=True, choices=[('new', 'New'), ('pending', 'Pending'), ('canceled', 'Canceled'), ('completed', 'Completed')], max_length=50, null=True, verbose_name='Old Status')),
|
|
||||||
('new_status', models.CharField(blank=True, choices=[('new', 'New'), ('pending', 'Pending'), ('canceled', 'Canceled'), ('completed', 'Completed')], max_length=50, null=True, verbose_name='New Status')),
|
|
||||||
('details', models.TextField(blank=True, null=True, verbose_name='Details')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('opportunity', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='logs', to='inventory.opportunity')),
|
|
||||||
('staff', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, to='inventory.staff', verbose_name='Staff')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Log',
|
|
||||||
'verbose_name_plural': 'Logs',
|
|
||||||
'ordering': ['-created_at'],
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='opportunity',
|
|
||||||
name='created_by',
|
|
||||||
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='deals_created', to='inventory.staff'),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='opportunity',
|
|
||||||
name='customer',
|
|
||||||
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='opportunities', to='inventory.customer'),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Notification',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('message', models.CharField(max_length=255, verbose_name='Message')),
|
|
||||||
('is_read', models.BooleanField(default=False, verbose_name='Is Read')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='notifications', to=settings.AUTH_USER_MODEL)),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Notification',
|
|
||||||
'verbose_name_plural': 'Notifications',
|
|
||||||
'ordering': ['-created_at'],
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='Notes',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('note', models.TextField(verbose_name='Note')),
|
|
||||||
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
|
||||||
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
|
||||||
('created_by', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='notes_created', to=settings.AUTH_USER_MODEL)),
|
|
||||||
('opportunity', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='notes', to='inventory.opportunity')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Notes',
|
|
||||||
'verbose_name_plural': 'Notes',
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='customer',
|
|
||||||
name='dealer',
|
|
||||||
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='customers', to='inventory.dealer'),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
|
||||||
name='CustomCard',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('custom_number', models.CharField(max_length=255, verbose_name='Custom Number')),
|
|
||||||
('custom_date', models.DateField(verbose_name='Custom Date')),
|
|
||||||
('car', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='custom_cards', to='inventory.car', verbose_name='Car')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Custom Card',
|
|
||||||
'verbose_name_plural': 'Custom Cards',
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='CarTrim',
|
name='CarTrim',
|
||||||
fields=[
|
fields=[
|
||||||
@ -499,20 +236,67 @@ class Migration(migrations.Migration):
|
|||||||
'verbose_name': 'Specification Value',
|
'verbose_name': 'Specification Value',
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='car',
|
||||||
|
name='id_car_trim',
|
||||||
|
field=models.ForeignKey(blank=True, db_column='id_car_trim', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.cartrim', verbose_name='Trim'),
|
||||||
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='CarRegistration',
|
name='CustomCard',
|
||||||
fields=[
|
fields=[
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
('plate_number', models.IntegerField(verbose_name='Plate Number')),
|
('custom_number', models.CharField(max_length=255, verbose_name='Custom Number')),
|
||||||
('text1', models.CharField(max_length=1, verbose_name='Text 1')),
|
('custom_date', models.DateField(verbose_name='Custom Date')),
|
||||||
('text2', models.CharField(max_length=1, verbose_name='Text 2')),
|
('car', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='custom_cards', to='inventory.car', verbose_name='Car')),
|
||||||
('text3', models.CharField(max_length=1, verbose_name='Text 3')),
|
|
||||||
('registration_date', models.DateTimeField(verbose_name='Registration Date')),
|
|
||||||
('car', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='registrations', to='inventory.car', verbose_name='Car')),
|
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
'verbose_name': 'Registration',
|
'verbose_name': 'Custom Card',
|
||||||
'verbose_name_plural': 'Registrations',
|
'verbose_name_plural': 'Custom Cards',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Dealer',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('crn', models.CharField(blank=True, max_length=10, null=True, verbose_name='Commercial Registration Number')),
|
||||||
|
('vrn', models.CharField(blank=True, max_length=15, null=True, verbose_name='VAT Registration Number')),
|
||||||
|
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
||||||
|
('name', models.CharField(max_length=255, verbose_name='English Name')),
|
||||||
|
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
||||||
|
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
||||||
|
('logo', models.ImageField(blank=True, null=True, upload_to='logos/users', verbose_name='Logo')),
|
||||||
|
('joined_at', models.DateTimeField(auto_now_add=True, verbose_name='Joined At')),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
||||||
|
('entity', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='django_ledger.entitymodel')),
|
||||||
|
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='dealer', to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Dealer',
|
||||||
|
'verbose_name_plural': 'Dealers',
|
||||||
|
},
|
||||||
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
|
managers=[
|
||||||
|
('objects', inventory.models.DealerUserManager()),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Customer',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('first_name', models.CharField(max_length=50, verbose_name='First Name')),
|
||||||
|
('middle_name', models.CharField(blank=True, max_length=50, null=True, verbose_name='Middle Name')),
|
||||||
|
('last_name', models.CharField(max_length=50, verbose_name='Last Name')),
|
||||||
|
('email', models.EmailField(max_length=254, unique=True, verbose_name='Email')),
|
||||||
|
('national_id', models.CharField(max_length=10, unique=True, verbose_name='National ID')),
|
||||||
|
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', unique=True, verbose_name='Phone Number')),
|
||||||
|
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
||||||
|
('created', models.DateTimeField(auto_now_add=True, verbose_name='Created')),
|
||||||
|
('is_lead', models.BooleanField(default=False, verbose_name='Is Lead')),
|
||||||
|
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='customers', to='inventory.dealer')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Customer',
|
||||||
|
'verbose_name_plural': 'Customers',
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
@ -531,51 +315,11 @@ class Migration(migrations.Migration):
|
|||||||
'verbose_name_plural': 'Car Locations',
|
'verbose_name_plural': 'Car Locations',
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
migrations.CreateModel(
|
|
||||||
name='CarFinance',
|
|
||||||
fields=[
|
|
||||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
|
||||||
('cost_price', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Cost Price')),
|
|
||||||
('selling_price', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Selling Price')),
|
|
||||||
('discount_amount', models.DecimalField(decimal_places=2, default=Decimal('0.00'), max_digits=14, verbose_name='Discount Amount')),
|
|
||||||
('additional_services', models.ManyToManyField(blank=True, related_name='additional_finances', to='django_ledger.itemmodel')),
|
|
||||||
('car', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='finances', to='inventory.car')),
|
|
||||||
],
|
|
||||||
options={
|
|
||||||
'verbose_name': 'Car Financial Details',
|
|
||||||
'verbose_name_plural': 'Car Financial Details',
|
|
||||||
},
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
migrations.AddField(
|
||||||
model_name='car',
|
model_name='car',
|
||||||
name='dealer',
|
name='dealer',
|
||||||
field=models.ForeignKey(on_delete=django.db.models.deletion.DO_NOTHING, related_name='cars', to='inventory.dealer', verbose_name='Dealer'),
|
field=models.ForeignKey(on_delete=django.db.models.deletion.DO_NOTHING, related_name='cars', to='inventory.dealer', verbose_name='Dealer'),
|
||||||
),
|
),
|
||||||
migrations.AddField(
|
|
||||||
model_name='car',
|
|
||||||
name='id_car_make',
|
|
||||||
field=models.ForeignKey(blank=True, db_column='id_car_make', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmake', verbose_name='Make'),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='car',
|
|
||||||
name='id_car_model',
|
|
||||||
field=models.ForeignKey(blank=True, db_column='id_car_model', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carmodel', verbose_name='Model'),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='car',
|
|
||||||
name='id_car_serie',
|
|
||||||
field=models.ForeignKey(blank=True, db_column='id_car_serie', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.carserie', verbose_name='Series'),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='car',
|
|
||||||
name='id_car_trim',
|
|
||||||
field=models.ForeignKey(blank=True, db_column='id_car_trim', null=True, on_delete=django.db.models.deletion.DO_NOTHING, to='inventory.cartrim', verbose_name='Trim'),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='car',
|
|
||||||
name='vendor',
|
|
||||||
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='cars', to='inventory.vendor', verbose_name='Vendor'),
|
|
||||||
),
|
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='AdditionalServices',
|
name='AdditionalServices',
|
||||||
fields=[
|
fields=[
|
||||||
@ -585,7 +329,7 @@ class Migration(migrations.Migration):
|
|||||||
('description', models.TextField(verbose_name='Description')),
|
('description', models.TextField(verbose_name='Description')),
|
||||||
('price', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Price')),
|
('price', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Price')),
|
||||||
('taxable', models.BooleanField(default=False, verbose_name='taxable')),
|
('taxable', models.BooleanField(default=False, verbose_name='taxable')),
|
||||||
('uom', models.CharField(choices=[('Unit', 'Unit'), ('Kg', 'Kg'), ('L', 'L'), ('m', 'm'), ('cm', 'cm'), ('m2', 'm2'), ('m3', 'm3'), ('m3', 'm3')], max_length=10, verbose_name='Unit of Measurement')),
|
('uom', models.CharField(choices=[('EA', 'Each'), ('PR', 'Pair'), ('SET', 'Set'), ('GAL', 'Gallon'), ('L', 'Liter'), ('M', 'Meter'), ('KG', 'Kilogram'), ('HR', 'Hour'), ('BX', 'Box'), ('RL', 'Roll'), ('PKG', 'Package'), ('DZ', 'Dozen'), ('SQ_M', 'Square Meter'), ('PC', 'Piece'), ('BDL', 'Bundle')], max_length=10, verbose_name='Unit of Measurement')),
|
||||||
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='inventory.dealer', verbose_name='Dealer')),
|
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='inventory.dealer', verbose_name='Dealer')),
|
||||||
],
|
],
|
||||||
options={
|
options={
|
||||||
@ -594,6 +338,272 @@ class Migration(migrations.Migration):
|
|||||||
},
|
},
|
||||||
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
),
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Notification',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('message', models.CharField(max_length=255, verbose_name='Message')),
|
||||||
|
('is_read', models.BooleanField(default=False, verbose_name='Is Read')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='notifications', to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Notification',
|
||||||
|
'verbose_name_plural': 'Notifications',
|
||||||
|
'ordering': ['-created_at'],
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Opportunity',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('deal_name', models.CharField(max_length=255, verbose_name='Deal Name')),
|
||||||
|
('deal_value', models.DecimalField(decimal_places=2, max_digits=10, verbose_name='Deal Value')),
|
||||||
|
('deal_status', models.CharField(choices=[('new', 'New'), ('pending', 'Pending'), ('canceled', 'Canceled'), ('completed', 'Completed')], default='new', max_length=20, verbose_name='Deal Status')),
|
||||||
|
('priority', models.CharField(choices=[('low', 'Low'), ('medium', 'Medium'), ('high', 'High')], default='low', max_length=10, verbose_name='Priority')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
||||||
|
('car', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, to='inventory.car', verbose_name='Car')),
|
||||||
|
('customer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='opportunities', to='inventory.customer')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Opportunity',
|
||||||
|
'verbose_name_plural': 'Opportunities',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Notes',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('note', models.TextField(verbose_name='Note')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
||||||
|
('created_by', models.ForeignKey(on_delete=django.db.models.deletion.DO_NOTHING, related_name='notes_created', to=settings.AUTH_USER_MODEL)),
|
||||||
|
('opportunity', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='notes', to='inventory.opportunity')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Notes',
|
||||||
|
'verbose_name_plural': 'Notes',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Organization',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('name', models.CharField(max_length=255, verbose_name='Name')),
|
||||||
|
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
||||||
|
('crn', models.CharField(max_length=15, verbose_name='Commercial Registration Number')),
|
||||||
|
('vrn', models.CharField(max_length=15, verbose_name='VAT Registration Number')),
|
||||||
|
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
||||||
|
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
||||||
|
('logo', models.ImageField(blank=True, null=True, upload_to='logos', verbose_name='Logo')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='organizations', to='inventory.dealer')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Organization',
|
||||||
|
'verbose_name_plural': 'Organizations',
|
||||||
|
},
|
||||||
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Refund',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('amount', models.DecimalField(decimal_places=2, max_digits=10, verbose_name='amount')),
|
||||||
|
('reason', models.TextField(blank=True, verbose_name='reason')),
|
||||||
|
('refund_date', models.DateField(auto_now_add=True, verbose_name='refund date')),
|
||||||
|
('payment', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='refund', to='inventory.payment')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'refund',
|
||||||
|
'verbose_name_plural': 'refunds',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Representative',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('name', models.CharField(max_length=255, verbose_name='Name')),
|
||||||
|
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
||||||
|
('id_number', models.CharField(max_length=10, verbose_name='ID Number')),
|
||||||
|
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
||||||
|
('email', models.EmailField(max_length=255, verbose_name='Email Address')),
|
||||||
|
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
||||||
|
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='representatives', to='inventory.dealer')),
|
||||||
|
('organization', models.ManyToManyField(related_name='representatives', to='inventory.organization')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Representative',
|
||||||
|
'verbose_name_plural': 'Representatives',
|
||||||
|
},
|
||||||
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='SaleQuotation',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('quotation_number', models.CharField(max_length=10, unique=True)),
|
||||||
|
('amount', models.DecimalField(decimal_places=2, default=Decimal('0.00'), max_digits=10, verbose_name='Amount')),
|
||||||
|
('remarks', models.TextField(blank=True, null=True, verbose_name='Remarks')),
|
||||||
|
('is_approved', models.BooleanField(default=False)),
|
||||||
|
('status', models.CharField(choices=[('Draft', 'Draft'), ('Approved', 'Approved'), ('In Review', 'In Review'), ('Paid', 'Paid')], default='Draft', max_length=10, verbose_name='Status')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
||||||
|
('posted', models.BooleanField(default=False)),
|
||||||
|
('payment_id', models.CharField(blank=True, max_length=255, null=True, verbose_name='Payment ID')),
|
||||||
|
('is_paid', models.BooleanField(default=False)),
|
||||||
|
('date_draft', models.DateTimeField(blank=True, null=True, verbose_name='Draft Date')),
|
||||||
|
('date_in_review', models.DateTimeField(blank=True, null=True, verbose_name='In Review Date')),
|
||||||
|
('date_approved', models.DateTimeField(blank=True, null=True, verbose_name='Approved Date')),
|
||||||
|
('date_paid', models.DateTimeField(blank=True, null=True, verbose_name='Paid Date')),
|
||||||
|
('date_void', models.DateTimeField(blank=True, null=True, verbose_name='Void Date')),
|
||||||
|
('date_canceled', models.DateTimeField(blank=True, null=True, verbose_name='Canceled Date')),
|
||||||
|
('customer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='quotations', to='inventory.customer', verbose_name='Customer')),
|
||||||
|
('dealer', models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, related_name='sales', to='inventory.dealer')),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='payment',
|
||||||
|
name='quotation',
|
||||||
|
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='payments', to='inventory.salequotation'),
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='SaleQuotationCar',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('quantity', models.PositiveIntegerField(default=1, verbose_name='Quantity')),
|
||||||
|
('car', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='inventory.car', verbose_name='Car')),
|
||||||
|
('quotation', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='quotation_cars', to='inventory.salequotation', verbose_name='Quotation')),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='SalesOrder',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('total_amount', models.DecimalField(decimal_places=2, max_digits=14, verbose_name='Total Amount')),
|
||||||
|
('quotation', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='sales_order', to='inventory.salequotation', verbose_name='Quotation')),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Staff',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('name', models.CharField(max_length=255, verbose_name='Name')),
|
||||||
|
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
||||||
|
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
||||||
|
('staff_type', models.CharField(choices=[('manager', 'Manager'), ('inventory', 'Inventory'), ('accountant', 'Accountant'), ('sales', 'Sales'), ('coordinator', 'Coordinator'), ('receptionist', 'Receptionist'), ('agent', 'Agent')], max_length=255, verbose_name='Staff Type')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Updated At')),
|
||||||
|
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='staff', to='inventory.dealer')),
|
||||||
|
('user', models.OneToOneField(on_delete=django.db.models.deletion.CASCADE, related_name='staff', to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Staff',
|
||||||
|
'verbose_name_plural': 'Staff',
|
||||||
|
'permissions': [],
|
||||||
|
},
|
||||||
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='OpportunityLog',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('action', models.CharField(choices=[('create', 'Create'), ('update', 'Update'), ('delete', 'Delete'), ('status_change', 'Status Change')], max_length=50, verbose_name='Action')),
|
||||||
|
('old_status', models.CharField(blank=True, choices=[('new', 'New'), ('pending', 'Pending'), ('canceled', 'Canceled'), ('completed', 'Completed')], max_length=50, null=True, verbose_name='Old Status')),
|
||||||
|
('new_status', models.CharField(blank=True, choices=[('new', 'New'), ('pending', 'Pending'), ('canceled', 'Canceled'), ('completed', 'Completed')], max_length=50, null=True, verbose_name='New Status')),
|
||||||
|
('details', models.TextField(blank=True, null=True, verbose_name='Details')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('opportunity', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='logs', to='inventory.opportunity')),
|
||||||
|
('staff', models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, to='inventory.staff', verbose_name='Staff')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Log',
|
||||||
|
'verbose_name_plural': 'Logs',
|
||||||
|
'ordering': ['-created_at'],
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='opportunity',
|
||||||
|
name='created_by',
|
||||||
|
field=models.ForeignKey(null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='deals_created', to='inventory.staff'),
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Subscription',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('start_date', models.DateField(help_text='Date when the subscription starts')),
|
||||||
|
('end_date', models.DateField(help_text='Date when the subscription ends')),
|
||||||
|
('is_active', models.BooleanField(default=True)),
|
||||||
|
('billing_cycle', models.CharField(choices=[('monthly', 'Monthly'), ('annual', 'Annual')], default='monthly', help_text='Billing cycle for the subscription', max_length=10)),
|
||||||
|
('last_payment_date', models.DateField(blank=True, help_text='Date of the last payment made', null=True)),
|
||||||
|
('next_payment_date', models.DateField(blank=True, help_text='Date of the next payment due', null=True)),
|
||||||
|
('plan', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='subscriptions', to='inventory.subscriptionplan')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Subscription',
|
||||||
|
'verbose_name_plural': 'Subscriptions',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='SubscriptionUser',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('subscription', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='inventory.subscription')),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Subscription User',
|
||||||
|
'verbose_name_plural': 'Subscription Users',
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='subscription',
|
||||||
|
name='users',
|
||||||
|
field=models.ManyToManyField(through='inventory.SubscriptionUser', to=settings.AUTH_USER_MODEL),
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='UserActivityLog',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('action', models.TextField()),
|
||||||
|
('timestamp', models.DateTimeField(auto_now_add=True)),
|
||||||
|
('user', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'User Activity Log',
|
||||||
|
'verbose_name_plural': 'User Activity Logs',
|
||||||
|
'ordering': ['-timestamp'],
|
||||||
|
},
|
||||||
|
),
|
||||||
|
migrations.CreateModel(
|
||||||
|
name='Vendor',
|
||||||
|
fields=[
|
||||||
|
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||||
|
('crn', models.CharField(max_length=10, unique=True, verbose_name='Commercial Registration Number')),
|
||||||
|
('vrn', models.CharField(max_length=15, unique=True, verbose_name='VAT Registration Number')),
|
||||||
|
('arabic_name', models.CharField(max_length=255, verbose_name='Arabic Name')),
|
||||||
|
('name', models.CharField(max_length=255, verbose_name='English Name')),
|
||||||
|
('contact_person', models.CharField(max_length=100, verbose_name='Contact Person')),
|
||||||
|
('phone_number', phonenumber_field.modelfields.PhoneNumberField(max_length=128, region='SA', verbose_name='Phone Number')),
|
||||||
|
('email', models.EmailField(max_length=255, verbose_name='Email Address')),
|
||||||
|
('address', models.CharField(blank=True, max_length=200, null=True, verbose_name='Address')),
|
||||||
|
('logo', models.ImageField(blank=True, null=True, upload_to='logos/vendors', verbose_name='Logo')),
|
||||||
|
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Created At')),
|
||||||
|
('dealer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='vendors', to='inventory.dealer')),
|
||||||
|
],
|
||||||
|
options={
|
||||||
|
'verbose_name': 'Vendor',
|
||||||
|
'verbose_name_plural': 'Vendors',
|
||||||
|
},
|
||||||
|
bases=(models.Model, inventory.mixins.LocalizedNameMixin),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='car',
|
||||||
|
name='vendor',
|
||||||
|
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.DO_NOTHING, related_name='cars', to='inventory.vendor', verbose_name='Vendor'),
|
||||||
|
),
|
||||||
migrations.CreateModel(
|
migrations.CreateModel(
|
||||||
name='CarReservation',
|
name='CarReservation',
|
||||||
fields=[
|
fields=[
|
||||||
|
|||||||
@ -1,124 +0,0 @@
|
|||||||
# Generated by Django 5.1.4 on 2025-01-05 09:01
|
|
||||||
|
|
||||||
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 = [
|
|
||||||
('inventory', '0001_initial'),
|
|
||||||
migrations.swappable_dependency(settings.AUTH_USER_MODEL),
|
|
||||||
]
|
|
||||||
|
|
||||||
operations = [
|
|
||||||
migrations.AlterModelOptions(
|
|
||||||
name='subscription',
|
|
||||||
options={'verbose_name': 'Subscription', 'verbose_name_plural': 'Subscriptions'},
|
|
||||||
),
|
|
||||||
migrations.AlterModelOptions(
|
|
||||||
name='subscriptionplan',
|
|
||||||
options={'verbose_name': 'Subscription Plan', 'verbose_name_plural': 'Subscription Plans'},
|
|
||||||
),
|
|
||||||
migrations.AlterModelOptions(
|
|
||||||
name='subscriptionuser',
|
|
||||||
options={'verbose_name': 'Subscription User', 'verbose_name_plural': 'Subscription Users'},
|
|
||||||
),
|
|
||||||
migrations.RemoveField(
|
|
||||||
model_name='opportunity',
|
|
||||||
name='source',
|
|
||||||
),
|
|
||||||
migrations.RemoveField(
|
|
||||||
model_name='subscription',
|
|
||||||
name='max_users',
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscription',
|
|
||||||
name='billing_cycle',
|
|
||||||
field=models.CharField(choices=[('monthly', 'Monthly'), ('annual', 'Annual')], default='monthly', help_text='Billing cycle for the subscription', max_length=10),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscription',
|
|
||||||
name='last_payment_date',
|
|
||||||
field=models.DateField(blank=True, help_text='Date of the last payment made', null=True),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscription',
|
|
||||||
name='next_payment_date',
|
|
||||||
field=models.DateField(blank=True, help_text='Date of the next payment due', null=True),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscriptionplan',
|
|
||||||
name='created_at',
|
|
||||||
field=models.DateTimeField(auto_now_add=True, default=django.utils.timezone.now),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscriptionplan',
|
|
||||||
name='custom_features',
|
|
||||||
field=models.JSONField(blank=True, help_text='Additional features specific to this plan', null=True),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscriptionplan',
|
|
||||||
name='max_inventory_size',
|
|
||||||
field=models.PositiveIntegerField(default=50, help_text='Maximum number of cars in inventory'),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscriptionplan',
|
|
||||||
name='support_level',
|
|
||||||
field=models.CharField(choices=[('basic', 'Basic Support'), ('priority', 'Priority Support'), ('dedicated', 'Dedicated Support')], default='basic', help_text='Level of support provided', max_length=50),
|
|
||||||
),
|
|
||||||
migrations.AddField(
|
|
||||||
model_name='subscriptionplan',
|
|
||||||
name='updated_at',
|
|
||||||
field=models.DateTimeField(auto_now=True),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='notes',
|
|
||||||
name='created_by',
|
|
||||||
field=models.ForeignKey(default=1, on_delete=django.db.models.deletion.DO_NOTHING, related_name='notes_created', to=settings.AUTH_USER_MODEL),
|
|
||||||
preserve_default=False,
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='opportunity',
|
|
||||||
name='deal_status',
|
|
||||||
field=models.CharField(choices=[('new', 'New'), ('pending', 'Pending'), ('canceled', 'Canceled'), ('completed', 'Completed')], default='new', max_length=20, verbose_name='Deal Status'),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='opportunity',
|
|
||||||
name='priority',
|
|
||||||
field=models.CharField(choices=[('low', 'Low'), ('medium', 'Medium'), ('high', 'High')], default='low', max_length=10, verbose_name='Priority'),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='staff',
|
|
||||||
name='staff_type',
|
|
||||||
field=models.CharField(choices=[('manager', 'Manager'), ('inventory', 'Inventory'), ('accountant', 'Accountant'), ('sales', 'Sales'), ('coordinator', 'Coordinator'), ('receptionist', 'Receptionist'), ('agent', 'Agent')], max_length=255, verbose_name='Staff Type'),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='subscription',
|
|
||||||
name='end_date',
|
|
||||||
field=models.DateField(help_text='Date when the subscription ends'),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='subscription',
|
|
||||||
name='plan',
|
|
||||||
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='subscriptions', to='inventory.subscriptionplan'),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='subscription',
|
|
||||||
name='start_date',
|
|
||||||
field=models.DateField(help_text='Date when the subscription starts'),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='subscriptionplan',
|
|
||||||
name='max_users',
|
|
||||||
field=models.PositiveIntegerField(default=1, help_text='Maximum number of users allowed'),
|
|
||||||
),
|
|
||||||
migrations.AlterField(
|
|
||||||
model_name='subscriptionplan',
|
|
||||||
name='name',
|
|
||||||
field=models.CharField(help_text='Name of the subscription plan', max_length=100, unique=True),
|
|
||||||
),
|
|
||||||
]
|
|
||||||
@ -6,7 +6,6 @@ from django_ledger.io import roles
|
|||||||
from django_ledger.models import EntityModel,AccountModel,ItemModel,ItemModelAbstract,UnitOfMeasureModel, VendorModel
|
from django_ledger.models import EntityModel,AccountModel,ItemModel,ItemModelAbstract,UnitOfMeasureModel, VendorModel
|
||||||
from . import models
|
from . import models
|
||||||
from .models import OpportunityLog
|
from .models import OpportunityLog
|
||||||
from .utils import get_dealer_from_instance
|
|
||||||
|
|
||||||
User = get_user_model()
|
User = get_user_model()
|
||||||
|
|
||||||
|
|||||||
BIN
static/images/.DS_Store
vendored
BIN
static/images/.DS_Store
vendored
Binary file not shown.
BIN
static/images/logos/.DS_Store
vendored
BIN
static/images/logos/.DS_Store
vendored
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user