From a2f96d3750a8a6a9f4731cf989a3eb6ac9309761 Mon Sep 17 00:00:00 2001 From: Andrey Smakotin Date: Thu, 13 Nov 2025 21:53:34 +0300 Subject: [PATCH] =?UTF-8?q?Replace=20'=D0=BA=D0=BE=D0=BD=D0=B5=D1=86'=20wi?= =?UTF-8?q?th=20'=D0=B8=D1=81=D1=85=D0=BE=D0=B4=20=D1=81=D0=B4=D0=B5=D0=BB?= =?UTF-8?q?=D0=BA=D0=B8'=20in=20order=20status=20terminology?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Updated terminology across the order status management system to use 'исход сделки' (deal outcome) instead of 'конец' (end) for better clarity and professional language. Changes: - Fixed AttributeError in order_status_list view by removing attempt to set read-only property orders_count - Updated OrderStatus model verbose_name fields for is_positive_end and is_negative_end - Updated status form template badges and preview JavaScript - Updated status list table header - Created migration for verbose_name changes 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude --- ...er_orderstatus_is_negative_end_and_more.py | 23 +++++++++++++++++++ myproject/orders/models.py | 4 ++-- .../orders/templates/orders/status_form.html | 8 +++---- .../orders/templates/orders/status_list.html | 2 +- myproject/orders/views.py | 5 ++-- 5 files changed, 32 insertions(+), 10 deletions(-) create mode 100644 myproject/orders/migrations/0004_alter_orderstatus_is_negative_end_and_more.py diff --git a/myproject/orders/migrations/0004_alter_orderstatus_is_negative_end_and_more.py b/myproject/orders/migrations/0004_alter_orderstatus_is_negative_end_and_more.py new file mode 100644 index 0000000..803e752 --- /dev/null +++ b/myproject/orders/migrations/0004_alter_orderstatus_is_negative_end_and_more.py @@ -0,0 +1,23 @@ +# Generated by Django 5.0.10 on 2025-11-13 18:51 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('orders', '0003_update_status_names_to_russian'), + ] + + operations = [ + migrations.AlterField( + model_name='orderstatus', + name='is_negative_end', + field=models.BooleanField(default=False, help_text='True если это финальный отрицательный статус (Отменен)', verbose_name='Отрицательный исход сделки'), + ), + migrations.AlterField( + model_name='orderstatus', + name='is_positive_end', + field=models.BooleanField(default=False, help_text='True если это финальный успешный статус (Выполнен)', verbose_name='Положительный исход сделки'), + ), + ] diff --git a/myproject/orders/models.py b/myproject/orders/models.py index bd0e0b7..d0c87d6 100644 --- a/myproject/orders/models.py +++ b/myproject/orders/models.py @@ -37,13 +37,13 @@ class OrderStatus(models.Model): is_positive_end = models.BooleanField( default=False, - verbose_name="Положительный конец", + verbose_name="Положительный исход сделки", help_text="True если это финальный успешный статус (Выполнен)" ) is_negative_end = models.BooleanField( default=False, - verbose_name="Отрицательный конец", + verbose_name="Отрицательный исход сделки", help_text="True если это финальный отрицательный статус (Отменен)" ) diff --git a/myproject/orders/templates/orders/status_form.html b/myproject/orders/templates/orders/status_form.html index 70b853f..474fe22 100644 --- a/myproject/orders/templates/orders/status_form.html +++ b/myproject/orders/templates/orders/status_form.html @@ -230,9 +230,9 @@

{% if form.instance.is_positive_end %} - ✓ Успешный конец + ✓ Успешный исход сделки {% elif form.instance.is_negative_end %} - ✗ Отрицательный конец + ✗ Отрицательный исход сделки {% else %} Промежуточный {% endif %} @@ -274,9 +274,9 @@ document.addEventListener('DOMContentLoaded', function() { // Обновляем тип конца if (positiveEndCheckbox.checked) { - previewEnd.innerHTML = '✓ Успешный конец'; + previewEnd.innerHTML = '✓ Успешный исход сделки'; } else if (negativeEndCheckbox.checked) { - previewEnd.innerHTML = '✗ Отрицательный конец'; + previewEnd.innerHTML = '✗ Отрицательный исход сделки'; } else { previewEnd.innerHTML = 'Промежуточный'; } diff --git a/myproject/orders/templates/orders/status_list.html b/myproject/orders/templates/orders/status_list.html index 70482e7..f38668a 100644 --- a/myproject/orders/templates/orders/status_list.html +++ b/myproject/orders/templates/orders/status_list.html @@ -41,7 +41,7 @@ Название Код Тип - Конец + Исход сделки Цвет Заказов Действия diff --git a/myproject/orders/views.py b/myproject/orders/views.py index 87ace4f..738d5f4 100644 --- a/myproject/orders/views.py +++ b/myproject/orders/views.py @@ -480,9 +480,8 @@ def order_status_list(request): """Список всех статусов заказов""" statuses = OrderStatus.objects.all().order_by('order', 'name') - # Добавляем информацию о количестве заказов для каждого статуса - for status in statuses: - status.orders_count = Order.objects.filter(status=status).count() + # orders_count уже доступен как property в модели OrderStatus + # Не нужно вручную добавлять атрибут context = { 'statuses': statuses,