feat: miodetail

This commit is contained in:
caoqianming 2023-10-27 16:19:11 +08:00
parent cbc43fdb65
commit 35052699da
4 changed files with 27 additions and 26 deletions

View File

@ -0,0 +1,19 @@
# Generated by Django 3.2.12 on 2023-10-26 08:24
from django.db import migrations, models
import django.db.models.deletion
class Migration(migrations.Migration):
dependencies = [
('inm', '0006_alter_mio_number'),
]
operations = [
migrations.AlterField(
model_name='mioitem',
name='mio',
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, related_name='item_mio', to='inm.mio', verbose_name='关联出入库'),
),
]

View File

@ -94,7 +94,7 @@ class MIOItem(BaseModel):
出入库明细
"""
mio = models.ForeignKey(MIO, verbose_name='关联出入库',
on_delete=models.CASCADE)
on_delete=models.CASCADE, related_name='item_mio')
warehouse = models.ForeignKey(
WareHouse, on_delete=models.CASCADE, verbose_name='仓库')
material = models.ForeignKey(

View File

@ -77,29 +77,6 @@ class MIOListSerializer(CustomModelSerializer):
read_only_fields = EXCLUDE_FIELDS + \
['state', 'submit_time', 'submit_user']
# def validate(self, attrs):
# if 'pu_order' in attrs and attrs['pu_order']:
# attrs['supplier'] = attrs['pu_order'].supplier
# if attrs['pu_order'].belong_dept:
# attrs['belong_dept'] = attrs['pu_order'].belong_dept
# elif 'order' in attrs and attrs['order']:
# attrs['customer'] = attrs['order'].customer
# return super().validate(attrs)
# def create(self, validated_data):
# type = validated_data['type']
# if type == MIO.MIO_TYPE_PUR_IN:
# pu_order = validated_data.get('pu_order', None)
# if pu_order and pu_order.state in [PuOrder.PUORDER_SUBMITED, PuOrder.PUORDER_SHIP]:
# pass
# else:
# raise ValidationError('该采购订单不可选')
# return super().create(validated_data)
# def update(self, instance, validated_data):
# validated_data.pop('type')
# return super().update(instance, validated_data)
class MIOItemACreateSerializer(CustomModelSerializer):
class Meta:
@ -244,3 +221,7 @@ class MIOOtherSerializer(CustomModelSerializer):
def update(self, instance, validated_data):
validated_data.pop('type')
return super().update(instance, validated_data)
class MIODetailSerializer(MIOListSerializer):
items = MIOItemSerializer(source='item_mio', many=True, read_only=True)

View File

@ -10,7 +10,7 @@ from rest_framework.response import Response
from apps.inm.models import WareHouse, MaterialBatch, MIO, MIOItem
from apps.inm.serializers import (
MaterialBatchSerializer, WareHourseSerializer, MIOListSerializer, MIOItemSerializer,
MIODoSerializer, MIOSaleSerializer, MIOPurSerializer, MIOOtherSerializer, MIOItemCreateSerializer, MaterialBatchDetailSerializer)
MIODoSerializer, MIOSaleSerializer, MIOPurSerializer, MIOOtherSerializer, MIOItemCreateSerializer, MaterialBatchDetailSerializer, MIODetailSerializer)
from apps.utils.viewsets import CustomGenericViewSet, CustomModelViewSet
from apps.inm.services import InmService
from apps.utils.mixins import BulkCreateModelMixin, BulkDestroyModelMixin, BulkUpdateModelMixin
@ -121,6 +121,7 @@ class MIOViewSet(CustomModelViewSet):
select_related_fields = ['create_by', 'belong_dept', 'do_user',
'submit_user', 'supplier', 'order', 'customer', 'pu_order']
serializer_class = MIOListSerializer
retrieve_serializer_class = MIODetailSerializer
filterset_fields = ['state', 'type', 'pu_order', 'order']
search_fields = ['number']
data_filter = True
@ -145,7 +146,7 @@ class MIOViewSet(CustomModelViewSet):
if not has_perm(user, ['mio.pur']):
raise PermissionDenied
return MIOPurSerializer
return self.serializer_class
return super().get_serializer_class()
def perform_destroy(self, instance):
if instance.state != MIO.MIO_CREATE: