feat: Реализовать систему поступления товаров с партиями (IncomingBatch)

Основные изменения:
- Создана модель IncomingBatch для группировки товаров по документам
- Каждое поступление (Incoming) связано с одной батчем поступления
- Автоматическое создание StockBatch для каждого товара в приходе
- Реализована система нумерации партий (IN-XXXX-XXXX) с поиском максимума в БД
- Обновлены все представления (views) для работы с новой архитектурой
- Добавлены детальные страницы просмотра партий поступлений
- Обновлены шаблоны для отображения информации о партиях и их товарах
- Исправлена логика сигналов для создания StockBatch при приходе товара
- Обновлены формы для работы с новой структурой IncomingBatch

Архитектура FIFO:
- IncomingBatch: одна партия поступления (номер IN-XXXX-XXXX)
- Incoming: товар в партии поступления
- StockBatch: одна партия товара на складе (создается для каждого товара)

Это позволяет системе правильно применять FIFO при продаже товаров.

🤖 Generated with Claude Code

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
2025-10-29 03:26:06 +03:00
parent 097d4ea304
commit 6735be9b08
73 changed files with 6536 additions and 122 deletions

View File

@@ -0,0 +1,25 @@
# -*- coding: utf-8 -*-
"""
SaleBatchAllocation (Распределение продаж по партиям) views - READ ONLY
GROUP 3: LOW PRIORITY - Аудит и трассировка FIFO
"""
from django.views.generic import ListView
from django.contrib.auth.mixins import LoginRequiredMixin
from ..models import SaleBatchAllocation
class SaleBatchAllocationListView(LoginRequiredMixin, ListView):
"""
Полный список всех распределений продаж по партиям.
Используется для аудита и понимания как применялся FIFO.
"""
model = SaleBatchAllocation
template_name = 'inventory/allocation/allocation_list.html'
context_object_name = 'allocations'
paginate_by = 30
def get_queryset(self):
return SaleBatchAllocation.objects.select_related(
'sale', 'sale__product',
'batch', 'batch__product'
).order_by('-sale__date')