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.word_alias.schemas.word_alias import WordAliasFilterSchema
from src.apps.wine.word_alias.services.word_alias import get_all_word_aliases

router = APIRouter(prefix="", tags=["Word Aliases"])

@router.get("", response_model=ResponseModel, summary="Get all Word Aliases")
async def list_word_aliases(
    db: Session = Depends(get_db),
    payload: WordAliasFilterSchema = Depends(),
    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_all_word_aliases(db=db,payload=payload, page=page, per_page=per_page)
    return ResponseModel(
        data=data,
        status_code=status.HTTP_200_OK,
        success=True,
        message="Word Aliases fetched successfully"
    )