Fix UI for inventory page 3

This commit is contained in:
Urtzi Alfaro
2025-09-16 12:21:15 +02:00
parent dd4016e217
commit 7aa26d51d3
15 changed files with 1660 additions and 2030 deletions

View File

@@ -141,6 +141,52 @@ class StockMovementRepository(BaseRepository[StockMovement, StockMovementCreate,
logger.error("Failed to get recent movements", error=str(e), tenant_id=tenant_id)
raise
async def get_movements(
self,
tenant_id: UUID,
skip: int = 0,
limit: int = 100,
ingredient_id: Optional[UUID] = None,
movement_type: Optional[str] = None
) -> List[StockMovement]:
"""Get stock movements with filtering"""
logger.info("🔍 Repository getting movements",
tenant_id=tenant_id,
ingredient_id=ingredient_id,
skip=skip,
limit=limit)
try:
query = select(self.model).where(self.model.tenant_id == tenant_id)
# Add filters
if ingredient_id:
query = query.where(self.model.ingredient_id == ingredient_id)
logger.info("🎯 Filtering by ingredient_id", ingredient_id=ingredient_id)
if movement_type:
# Convert string to enum
try:
movement_type_enum = StockMovementType(movement_type)
query = query.where(self.model.movement_type == movement_type_enum)
logger.info("🏷️ Filtering by movement_type", movement_type=movement_type)
except ValueError:
logger.warning("⚠️ Invalid movement type", movement_type=movement_type)
# Invalid movement type, skip filter
pass
# Order by date (newest first) and apply pagination
query = query.order_by(desc(self.model.movement_date)).offset(skip).limit(limit)
result = await self.session.execute(query)
movements = result.scalars().all()
logger.info("🔢 Repository found movements", count=len(movements))
return movements
except Exception as e:
logger.error("❌ Repository failed to get movements", error=str(e), tenant_id=tenant_id)
raise
async def get_movements_by_reference(
self,
tenant_id: UUID,