from typing import List
from fastapi import APIRouter, Depends
from sqlalchemy.orm import Session
from app.api.sales import schema
from app.api.sales.service import SalesService
from app.database.main.mysql import get_db
from app.dependency.authantication import JWTPayloadSchema, get_current_student

sales_router = APIRouter()

@sales_router.post("/create_sales", response_model_exclude_none=True)
async def create_sales(request:List[schema.SalesCreate], db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await SalesService(db,token).create_sales(request)

# @sales_router.post("/create_sales", response_model_exclude_none=True)
# async def create_sales(
#     request: List[schema.SalesCreate],
#     db: Session = Depends(get_db),
#     token: JWTPayloadSchema = Depends(get_current_student),
# ):
#     return await SalesService(db, token).create_sales(request)

@sales_router.get("/get_sales{group_id}", response_model_exclude_none=True)
async def get_sales(group_id:int, db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await SalesService(db,token).get_sales(group_id)

@sales_router.get("/get_multiple_sales", response_model_exclude_none=True)
async def get_multiple_sales(get_id:int, db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await SalesService(db,token).get_multiple(get_id)

@sales_router.put("/update_sales", response_model_exclude_none=True)
async def  update_sales(request:List[schema.SalesUpdate], db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await SalesService(db,token).update_sales(request)

@sales_router.delete("/delete_sales", response_model_exclude_none=True)
async def delete_sales (sales_id:int, db:Session = Depends(get_db), token:JWTPayloadSchema = Depends(get_current_student)):
    return await SalesService(db,token).delete_sales(sales_id)