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

sales_estimate_router = APIRouter()

@sales_estimate_router.post("/create_sales_estimate", response_model_exclude_none=True)
async def create_sales_estimate(request:List[schema.SalesEstimateCreate], db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await SalesEstimateService(db,token).create_sales_estimate(request)

@sales_estimate_router.get("/get_sales_estimate", response_model_exclude_none=True)
async def get_sales_estimate(sales_get_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await SalesEstimateService(db,token).get_sales_estimate(sales_get_id)

@sales_estimate_router.get("/get_group_sales_estimate", response_model_exclude_none=True)
async def get_group_sales_estimate(group_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await SalesEstimateService(db,token).get_group_sales_estimate(group_id)

@sales_estimate_router.get("/get_multiple", response_model_exclude_none=True)
async def get_multiple(group_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await SalesEstimateService(db,token).get_sales_value_sales_estimate(group_id)

@sales_estimate_router.put("/update_sales_estimate", response_model_exclude_none=True)
async def update_sales_estimate(request:List[schema.SalesEstimateUpdate], db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await SalesEstimateService(db,token).update_sales_estimate(request)

@sales_estimate_router.delete("/delete_sales_estimate", response_model_exclude_none=True)
async def deleted_sales_estimate(sales_id:int, db:Session = Depends(get_db),token: JWTPayloadSchema = Depends(get_current_student)):
    return await SalesEstimateService(db,token).delete_sales_estimate(sales_id)