Улучшения в тестах переходов статусов заказов

- Исправлены комментарии и форматирование в signals.py
- Улучшена читаемость кода в models.py
- Обновлены шаблоны форм статусов
- Доработаны тесты переходов статусов
This commit is contained in:
2026-01-05 21:30:25 +03:00
parent 70f0e4fb4c
commit 2aba3d2404
5 changed files with 400 additions and 121 deletions

View File

@@ -1,4 +1,5 @@
from django.db import models
from django.core.exceptions import ValidationError
from accounts.models import CustomUser
@@ -90,10 +91,24 @@ class OrderStatus(models.Model):
models.Index(fields=['is_system']),
models.Index(fields=['order']),
]
constraints = [
models.CheckConstraint(
check=~(models.Q(is_positive_end=True) & models.Q(is_negative_end=True)),
name='not_both_positive_and_negative_end',
violation_error_message="Статус не может быть одновременно положительным и отрицательным концом"
)
]
def __str__(self):
return self.name
def clean(self):
"""Валидация модели перед сохранением"""
if self.is_positive_end and self.is_negative_end:
raise ValidationError(
"Статус не может быть одновременно положительным и отрицательным концом"
)
@property
def orders_count(self):
"""Количество заказов в этом статусе"""

View File

@@ -294,6 +294,21 @@ document.addEventListener('DOMContentLoaded', function() {
positiveEndCheckbox.addEventListener('change', updatePreview);
negativeEndCheckbox.addEventListener('change', updatePreview);
// Взаимное отключение чекбоксов: нельзя быть одновременно положительным и отрицательным
positiveEndCheckbox.addEventListener('change', function() {
if (this.checked) {
negativeEndCheckbox.checked = false;
}
updatePreview();
});
negativeEndCheckbox.addEventListener('change', function() {
if (this.checked) {
positiveEndCheckbox.checked = false;
}
updatePreview();
});
// Инициальное обновление
updatePreview();
});