Обновили шапку и вывод всехтоваров. Добавили фильтры

This commit is contained in:
2025-10-24 23:11:29 +03:00
parent 2fb6253d06
commit 9ad9f604e9
35 changed files with 2498 additions and 1270 deletions

View File

@@ -0,0 +1,101 @@
# Generated by Django 5.2.7 on 2025-10-23 23:46
import django.db.models.deletion
import phonenumber_field.modelfields
from django.db import migrations, models
class Migration(migrations.Migration):
initial = True
dependencies = [
('products', '0001_initial'),
]
operations = [
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=100, verbose_name='Имя')),
('last_name', models.CharField(max_length=100, verbose_name='Фамилия')),
('email', models.EmailField(max_length=254, unique=True, verbose_name='Email')),
('phone', phonenumber_field.modelfields.PhoneNumberField(blank=True, help_text='Телефон в международном формате (например, +375291234567)', max_length=128, null=True, region=None, verbose_name='Телефон')),
('preferred_colors', models.CharField(blank=True, help_text="Предпочтительные цветы цветов, например: 'красный, белый, желтый'", max_length=200, null=True, verbose_name='Предпочтительные цвета')),
('loyalty_tier', models.CharField(choices=[('bronze', 'Бронза'), ('silver', 'Серебро'), ('gold', 'Золото'), ('platinum', 'Платина')], default='bronze', max_length=20, verbose_name='Уровень лояльности')),
('total_spent', models.DecimalField(decimal_places=2, default=0, max_digits=10, verbose_name='Общая сумма покупок')),
('birthday', models.DateField(blank=True, null=True, verbose_name='День рождения')),
('anniversary', models.DateField(blank=True, null=True, verbose_name='Годовщина')),
('notes', models.TextField(blank=True, help_text='Заметки о клиенте, особые предпочтения и т.д.', null=True, verbose_name='Заметки')),
('is_active', models.BooleanField(default=True, verbose_name='Активный клиент')),
('is_vip', models.BooleanField(default=False, verbose_name='VIP клиент')),
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Дата создания')),
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Дата обновления')),
('favorite_flower_types', models.ManyToManyField(blank=True, related_name='preferred_by_customers', to='products.product', verbose_name='Любимые виды цветов')),
],
options={
'verbose_name': 'Клиент',
'verbose_name_plural': 'Клиенты',
'ordering': ['-created_at'],
},
),
migrations.CreateModel(
name='Address',
fields=[
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
('recipient_name', models.CharField(help_text='Имя человека, которому будет доставлен заказ', max_length=200, verbose_name='Имя получателя')),
('street', models.CharField(max_length=255, verbose_name='Улица')),
('building_number', models.CharField(max_length=20, verbose_name='Номер здания')),
('apartment_number', models.CharField(blank=True, max_length=20, null=True, verbose_name='Номер квартиры/офиса')),
('district', models.CharField(blank=True, help_text='Район в Минске для удобства доставки', max_length=100, null=True, verbose_name='Район')),
('delivery_instructions', models.TextField(blank=True, help_text='Дополнительные инструкции для курьера (домофон, подъезд и т.д.)', null=True, verbose_name='Инструкции для доставки')),
('is_default', models.BooleanField(default=False, help_text='Использовать этот адрес для доставки по умолчанию', verbose_name='Адрес по умолчанию')),
('is_active', models.BooleanField(default=True, verbose_name='Активный адрес')),
('created_at', models.DateTimeField(auto_now_add=True, verbose_name='Дата создания')),
('updated_at', models.DateTimeField(auto_now=True, verbose_name='Дата обновления')),
('customer', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='addresses', to='customers.customer', verbose_name='Клиент')),
],
options={
'verbose_name': 'Адрес доставки',
'verbose_name_plural': 'Адреса доставки',
'ordering': ['-is_default', '-created_at'],
},
),
migrations.AddIndex(
model_name='customer',
index=models.Index(fields=['email'], name='customers_c_email_4fdeb3_idx'),
),
migrations.AddIndex(
model_name='customer',
index=models.Index(fields=['phone'], name='customers_c_phone_8493fa_idx'),
),
migrations.AddIndex(
model_name='customer',
index=models.Index(fields=['created_at'], name='customers_c_created_1ed0f4_idx'),
),
migrations.AddIndex(
model_name='customer',
index=models.Index(fields=['is_active'], name='customers_c_is_acti_91d305_idx'),
),
migrations.AddIndex(
model_name='customer',
index=models.Index(fields=['loyalty_tier'], name='customers_c_loyalty_5162a0_idx'),
),
migrations.AddIndex(
model_name='address',
index=models.Index(fields=['customer'], name='customers_a_custome_53b543_idx'),
),
migrations.AddIndex(
model_name='address',
index=models.Index(fields=['is_default'], name='customers_a_is_defa_631851_idx'),
),
migrations.AddIndex(
model_name='address',
index=models.Index(fields=['is_active'], name='customers_a_is_acti_433713_idx'),
),
migrations.AddIndex(
model_name='address',
index=models.Index(fields=['district'], name='customers_a_distric_ac47d5_idx'),
),
]

View File

@@ -0,0 +1,56 @@
# Generated by Django 5.2.7 on 2025-10-24 07:52
from django.db import migrations, models
class Migration(migrations.Migration):
dependencies = [
('customers', '0001_initial'),
]
operations = [
migrations.RemoveField(
model_name='customer',
name='anniversary',
),
migrations.RemoveField(
model_name='customer',
name='birthday',
),
migrations.RemoveField(
model_name='customer',
name='favorite_flower_types',
),
migrations.RemoveField(
model_name='customer',
name='first_name',
),
migrations.RemoveField(
model_name='customer',
name='last_name',
),
migrations.RemoveField(
model_name='customer',
name='preferred_colors',
),
migrations.AddField(
model_name='customer',
name='name',
field=models.CharField(blank=True, max_length=200, verbose_name='Имя'),
),
migrations.AlterField(
model_name='customer',
name='email',
field=models.EmailField(blank=True, max_length=254, verbose_name='Email'),
),
migrations.AlterField(
model_name='customer',
name='loyalty_tier',
field=models.CharField(choices=[('no_discount', 'Без скидки'), ('bronze', 'Бронза'), ('silver', 'Серебро'), ('gold', 'Золото'), ('platinum', 'Платина')], default='no_discount', max_length=20, verbose_name='Уровень лояльности'),
),
migrations.AddIndex(
model_name='customer',
index=models.Index(fields=['name'], name='customers_c_name_f018e2_idx'),
),
]

View File

@@ -0,0 +1,19 @@
# Generated by Django 5.2.7 on 2025-10-24 14:55
import phonenumber_field.modelfields
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('customers', '0002_remove_customer_anniversary_remove_customer_birthday_and_more'),
]
operations = [
migrations.AlterField(
model_name='customer',
name='phone',
field=phonenumber_field.modelfields.PhoneNumberField(blank=True, help_text='Введите телефон в любом формате, например: +375291234567, 80255270546, 8(029)1234567 - будет автоматически преобразован в международный формат', max_length=128, null=True, region=None, verbose_name='Телефон'),
),
]

View File

@@ -0,0 +1,33 @@
# Generated by Django 5.2.7 on 2025-10-24 16:57
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('customers', '0003_alter_customer_phone'),
]
operations = [
migrations.RemoveIndex(
model_name='address',
name='customers_a_is_acti_433713_idx',
),
migrations.RemoveIndex(
model_name='customer',
name='customers_c_is_acti_91d305_idx',
),
migrations.RemoveField(
model_name='address',
name='is_active',
),
migrations.RemoveField(
model_name='customer',
name='is_active',
),
migrations.RemoveField(
model_name='customer',
name='is_vip',
),
]

View File

@@ -0,0 +1,19 @@
# Generated by Django 5.2.7 on 2025-10-24 17:01
import phonenumber_field.modelfields
from django.db import migrations
class Migration(migrations.Migration):
dependencies = [
('customers', '0004_remove_address_customers_a_is_acti_433713_idx_and_more'),
]
operations = [
migrations.AlterField(
model_name='customer',
name='phone',
field=phonenumber_field.modelfields.PhoneNumberField(blank=True, help_text='Введите телефон в любом формате, например: +375291234567, 80255270546, 8(029)1234567 - будет автоматически преобразован в международный формат', max_length=128, null=True, region=None, unique=True, verbose_name='Телефон'),
),
]