Files
octopus/myproject/inventory/views/allocation.py
Andrey Smakotin 6735be9b08 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>
2025-10-29 03:26:06 +03:00

26 lines
981 B
Python

# -*- 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')