from fastapi import APIRouter, Depends, Query, status
from sqlalchemy.orm import Session
from uuid import UUID

from src.apps.base.schemas.response_model import ResponseModel
from src.utils import constants
from src.core.dependencies import get_db
from src.utils.constants import MAX_PER_PAGE
from typing import Optional
from src.apps.wine.appellation.services.appellation import (
    get_appellations,
    create_appellation,
    update_appellation,
    get_appellations_by_id,
    delete_appellation
)
from src.apps.wine.appellation.schemas.appellation import (
    AppellationCreateSchema,
    AppellationUpdateSchema,
    AppellationOutputSchema
)

router = APIRouter(prefix="", tags=["Appellations"])

@router.get("", response_model=ResponseModel, summary="Get all appellations")
async def list_appellations(
    db: Session = Depends(get_db),
    page: int = Query(default=1, ge=1, description="Page number"),
    per_page: int = Query(
        default=constants.DEFAULT_PER_PAGE,
        ge=1,
        le=constants.MAX_PER_PAGE,
        description="Items per page",
    ),
):
    data = await get_appellations(db=db, page=page, per_page=per_page)
    return ResponseModel(
        data=data,
        status_code=status.HTTP_200_OK,
        success=True,
        message="Appellations fetched successfully"
    )
    
@router.post("", response_model=ResponseModel, summary="Create a new appellation")
async def create_new_appellation(
    payload: AppellationCreateSchema,
    db: Session = Depends(get_db),
):

    data = await create_appellation(db, payload)
    return ResponseModel(
        data=data,
        status_code=status.HTTP_201_CREATED,
        success=True,
        message="Appellation created successfully"
    )

@router.get("/{appellation_id}", response_model=ResponseModel, summary="Get a appellation by ID")
async def get_appellation(
    appellation_id: int,
    db: Session = Depends(get_db),
):
    data = await get_appellations_by_id(db, appellation_id)
    return ResponseModel(
        data=AppellationOutputSchema.model_validate(data),
        status_code=status.HTTP_200_OK,
        success=True,
        message="Appellation fetched successfully"
    )


@router.put("/{appellation_id}", response_model=ResponseModel, summary="Update a appellation by ID")
async def update_existing_appellation(
    appellation_id: int,
    payload: AppellationUpdateSchema,
    db: Session = Depends(get_db),
):
    data = await update_appellation(db, appellation_id, payload)
    return ResponseModel(
        data=data,
        status_code=status.HTTP_200_OK,
        success=True,
        message="Appellation updated successfully"
    )
    
@router.delete("/{appellation_id}", response_model=ResponseModel, summary="Delete a appellation by ID")
async def delete_appellation_by_id(
    appellation_id: int,
    db: Session = Depends(get_db),
):
    data = await delete_appellation(db, appellation_id)
    return ResponseModel(
        data={},
        status_code=status.HTTP_204_NO_CONTENT,
        success=True,
        message="Appellation deleted successfully"
    )
    
    