feat: a few shipping products in box
This commit is contained in:
@@ -5,7 +5,7 @@ from sqlalchemy.orm import Mapped, mapped_column, relationship
|
||||
from models import BaseModel
|
||||
|
||||
if TYPE_CHECKING:
|
||||
from models import Card, Product, Client
|
||||
from models import Card, Product
|
||||
|
||||
|
||||
class Pallet(BaseModel):
|
||||
@@ -30,6 +30,24 @@ class Pallet(BaseModel):
|
||||
)
|
||||
|
||||
|
||||
class Box(BaseModel):
|
||||
__tablename__ = 'boxes'
|
||||
id: Mapped[int] = mapped_column(primary_key=True)
|
||||
|
||||
shipping_products: Mapped[list['ShippingProduct']] = relationship(
|
||||
back_populates='box',
|
||||
uselist=True,
|
||||
lazy='joined',
|
||||
cascade='all, delete-orphan',
|
||||
)
|
||||
|
||||
pallet_id: Mapped[Optional[int]] = mapped_column(ForeignKey('pallets.id'))
|
||||
pallet: Mapped[Pallet] = relationship(back_populates='boxes')
|
||||
|
||||
card_id: Mapped[Optional[int]] = mapped_column(ForeignKey('cards.id'))
|
||||
card: Mapped['Card'] = relationship(back_populates='boxes')
|
||||
|
||||
|
||||
class ShippingProduct(BaseModel):
|
||||
__tablename__ = 'shipping_products'
|
||||
id: Mapped[int] = mapped_column(primary_key=True)
|
||||
@@ -38,21 +56,8 @@ class ShippingProduct(BaseModel):
|
||||
product_id: Mapped[int] = mapped_column(ForeignKey('products.id'))
|
||||
product: Mapped['Product'] = relationship(lazy='joined')
|
||||
|
||||
pallet_id: Mapped[int] = mapped_column(ForeignKey('pallets.id'))
|
||||
pallet: Mapped['Pallet'] = relationship(lazy='joined')
|
||||
|
||||
|
||||
class Box(BaseModel):
|
||||
__tablename__ = 'boxes'
|
||||
id: Mapped[int] = mapped_column(primary_key=True)
|
||||
|
||||
quantity: Mapped[int] = mapped_column(default=0)
|
||||
|
||||
product_id: Mapped[Optional[int]] = mapped_column(ForeignKey('products.id'), nullable=True)
|
||||
product: Mapped['Product'] = relationship(lazy='joined')
|
||||
|
||||
pallet_id: Mapped[Optional[int]] = mapped_column(ForeignKey('pallets.id'))
|
||||
pallet: Mapped[Pallet] = relationship(back_populates='boxes')
|
||||
pallet: Mapped[Optional['Pallet']] = relationship(lazy='joined')
|
||||
|
||||
card_id: Mapped[Optional[int]] = mapped_column(ForeignKey('cards.id'))
|
||||
card: Mapped['Card'] = relationship(back_populates='boxes')
|
||||
box_id: Mapped[Optional[int]] = mapped_column(ForeignKey('boxes.id'))
|
||||
box: Mapped[Optional['Box']] = relationship(lazy='joined')
|
||||
|
||||
@@ -68,15 +68,15 @@ async def delete_shipping_product(
|
||||
|
||||
@shipping_router.post(
|
||||
'/box',
|
||||
response_model=UpdateBoxResponse,
|
||||
operation_id='update_box',
|
||||
response_model=CreateBoxResponse,
|
||||
operation_id='create_box',
|
||||
dependencies=[Depends(authorized_user)],
|
||||
)
|
||||
async def update_box(
|
||||
async def create_box(
|
||||
session: SessionDependency,
|
||||
request: UpdateBoxRequest,
|
||||
request: CreateBoxRequest,
|
||||
):
|
||||
return await ShippingService(session).update_box(request)
|
||||
return await ShippingService(session).create_box(request)
|
||||
|
||||
|
||||
@shipping_router.delete(
|
||||
|
||||
@@ -11,19 +11,19 @@ class ProductAndQuantitySchema(BaseSchema):
|
||||
quantity: Optional[int]
|
||||
|
||||
|
||||
class BoxSchema(BaseSchema):
|
||||
id: int
|
||||
quantity: int
|
||||
product: Optional[ProductSchema]
|
||||
pallet_id: Optional[int]
|
||||
card_id: Optional[int]
|
||||
|
||||
|
||||
class ShippingProductSchema(BaseSchema):
|
||||
id: int
|
||||
quantity: int
|
||||
product: ProductSchema
|
||||
pallet_id: int
|
||||
pallet_id: Optional[int]
|
||||
box_id: Optional[int]
|
||||
|
||||
|
||||
class BoxSchema(BaseSchema):
|
||||
id: int
|
||||
pallet_id: Optional[int]
|
||||
card_id: Optional[int]
|
||||
shipping_products: list[ShippingProductSchema]
|
||||
|
||||
|
||||
class PalletSchema(BaseSchema):
|
||||
@@ -33,7 +33,8 @@ class PalletSchema(BaseSchema):
|
||||
|
||||
|
||||
class CreateShippingProductSchema(ProductAndQuantitySchema):
|
||||
pallet_id: int
|
||||
pallet_id: Optional[int] = None
|
||||
box_id: Optional[int] = None
|
||||
|
||||
|
||||
class UpdateShippingProductSchema(ProductAndQuantitySchema):
|
||||
@@ -48,10 +49,6 @@ class CreateBoxInCardSchema(BaseSchema):
|
||||
card_id: Optional[int]
|
||||
|
||||
|
||||
class UpdateBoxSchema(ProductAndQuantitySchema):
|
||||
box_id: Optional[int]
|
||||
|
||||
|
||||
# endregion
|
||||
|
||||
# region Requests
|
||||
@@ -60,8 +57,8 @@ class UpdateShippingProductRequest(BaseSchema):
|
||||
data: CreateShippingProductSchema | UpdateShippingProductSchema
|
||||
|
||||
|
||||
class UpdateBoxRequest(BaseSchema):
|
||||
data: CreateBoxInCardSchema | CreateBoxInPalletSchema | UpdateBoxSchema
|
||||
class CreateBoxRequest(BaseSchema):
|
||||
data: CreateBoxInCardSchema | CreateBoxInPalletSchema
|
||||
|
||||
|
||||
# endregion
|
||||
@@ -80,7 +77,7 @@ class UpdateShippingProductResponse(OkMessageSchema):
|
||||
pass
|
||||
|
||||
|
||||
class UpdateBoxResponse(OkMessageSchema):
|
||||
class CreateBoxResponse(OkMessageSchema):
|
||||
pass
|
||||
|
||||
|
||||
|
||||
@@ -322,7 +322,8 @@ class CardsService(BaseService):
|
||||
.selectinload(ShippingProduct.product)
|
||||
.noload(Product.barcodes),
|
||||
selectinload(Card.boxes)
|
||||
.selectinload(Box.product)
|
||||
.selectinload(Box.shipping_products)
|
||||
.selectinload(ShippingProduct.product)
|
||||
.noload(Product.barcodes),
|
||||
selectinload(Card.employees)
|
||||
.joinedload(CardEmployees.user),
|
||||
|
||||
@@ -26,16 +26,6 @@ class ShippingService(BaseService):
|
||||
await self.session.commit()
|
||||
return DeletePalletResponse(ok=True, message="Паллет успешно удален")
|
||||
|
||||
async def _update_box(self, data: UpdateBoxSchema) -> tuple[bool, str]:
|
||||
box = await self.session.get(Box, data.box_id)
|
||||
if not box:
|
||||
return False, f"Короб с ID:{data.box_id} не найден"
|
||||
|
||||
box.quantity = data.quantity
|
||||
box.product_id = data.product_id
|
||||
await self.session.commit()
|
||||
return True, "Короб обновлен"
|
||||
|
||||
async def _create_box(self, data: CreateBoxInCardSchema | CreateBoxInPalletSchema):
|
||||
box = Box(**data.model_dump())
|
||||
self.session.add(box)
|
||||
@@ -59,16 +49,14 @@ class ShippingService(BaseService):
|
||||
|
||||
return True, f"Короб добавлен в паллет"
|
||||
|
||||
async def update_box(self, request: UpdateBoxRequest) -> UpdateBoxResponse:
|
||||
async def create_box(self, request: CreateBoxRequest) -> CreateBoxResponse:
|
||||
data_keys = request.data.model_dump().keys()
|
||||
if "box_id" in data_keys:
|
||||
ok, message = await self._update_box(request.data)
|
||||
elif "pallet_id" in data_keys:
|
||||
if "pallet_id" in data_keys:
|
||||
ok, message = await self._create_box_in_pallet(CreateBoxInPalletSchema.model_validate(request.data))
|
||||
else:
|
||||
ok, message = await self._create_box_in_card(CreateBoxInCardSchema.model_validate(request.data))
|
||||
|
||||
return UpdateBoxResponse(ok=ok, message=message)
|
||||
return CreateBoxResponse(ok=ok, message=message)
|
||||
|
||||
async def delete_box(self, deal_id: int) -> DeleteBoxResponse:
|
||||
box = await self.session.get(Box, deal_id)
|
||||
@@ -94,13 +82,13 @@ class ShippingService(BaseService):
|
||||
shipping_product.product_id = data.product_id
|
||||
shipping_product.quantity = data.quantity
|
||||
await self.session.commit()
|
||||
return True, "Запись о товаре на паллете успешно изменена"
|
||||
return True, "Запись о товаре успешно изменена"
|
||||
|
||||
async def _create_shipping_product(self, data: CreateShippingProductSchema) -> tuple[bool, str]:
|
||||
shipping_product = ShippingProduct(**data.model_dump())
|
||||
self.session.add(shipping_product)
|
||||
await self.session.commit()
|
||||
return True, "Запись о товаре на паллете успешно добавлена"
|
||||
return True, "Запись о товаре успешно добавлена"
|
||||
|
||||
async def update_shipping_product(self, request: UpdateShippingProductRequest) -> UpdateShippingProductResponse:
|
||||
data_keys = request.data.model_dump().keys()
|
||||
|
||||
Reference in New Issue
Block a user