Player List (and default responseClass)

This commit is contained in:
Jack Jackson 2024-02-11 15:07:29 -08:00
parent e7831948b2
commit 7e54b9dc65
4 changed files with 69 additions and 10 deletions

View File

@ -9,9 +9,16 @@ from ..sql.database import get_db
from .players import list_players from .players import list_players
api_router = APIRouter(prefix="/deck", tags=["deck"]) api_router = APIRouter(prefix="/deck", tags=["deck"])
html_router = APIRouter(prefix="/deck", include_in_schema=False) html_router = APIRouter(
prefix="/deck",
include_in_schema=False,
default_response_class=HTMLResponse)
########
# API Routes
########
@api_router.post("/", response_model=schemas.Deck, status_code=201) @api_router.post("/", response_model=schemas.Deck, status_code=201)
def create_deck(deck: schemas.DeckCreate, db: Session = Depends(get_db)): def create_deck(deck: schemas.DeckCreate, db: Session = Depends(get_db)):
db_player = crud.get_player_by_id(db, deck.owner_id) db_player = crud.get_player_by_id(db, deck.owner_id)
@ -42,7 +49,11 @@ def delete_deck(deck_id: str, db=Depends(get_db)):
crud.delete_deck_by_id(db, int(deck_id)) crud.delete_deck_by_id(db, int(deck_id))
@html_router.get("/create", response_class=HTMLResponse) ########
# HTML Routes
########
@html_router.get("/create")
def deck_create_html(request: Request, db=Depends(get_db)): def deck_create_html(request: Request, db=Depends(get_db)):
players = list_players(db=db) players = list_players(db=db)
return jinja_templates.TemplateResponse( return jinja_templates.TemplateResponse(
@ -51,7 +62,7 @@ def deck_create_html(request: Request, db=Depends(get_db)):
# TODO - pagination # TODO - pagination
@html_router.get("/list", response_class=HTMLResponse) @html_router.get("/list")
def decks_html(request: Request, db=Depends(get_db)): def decks_html(request: Request, db=Depends(get_db)):
decks = list_decks(db=db) decks = list_decks(db=db)
return jinja_templates.TemplateResponse( return jinja_templates.TemplateResponse(
@ -60,7 +71,7 @@ def decks_html(request: Request, db=Depends(get_db)):
# This must be after the static-path routes, lest it take priority over them # This must be after the static-path routes, lest it take priority over them
@html_router.get("/{deck_id}", response_class=HTMLResponse) @html_router.get("/{deck_id}")
def deck_html(request: Request, deck_id: str, db=Depends(get_db)): def deck_html(request: Request, deck_id: str, db=Depends(get_db)):
deck_info = read_deck(deck_id, db) deck_info = read_deck(deck_id, db)
return jinja_templates.TemplateResponse( return jinja_templates.TemplateResponse(

View File

@ -10,7 +10,14 @@ from ..sql import crud, schemas
from ..sql.database import get_db from ..sql.database import get_db
api_router = APIRouter(prefix="/game", tags=["game"]) api_router = APIRouter(prefix="/game", tags=["game"])
html_router = APIRouter(prefix="/game", include_in_schema=False) html_router = APIRouter(
prefix="/game",
include_in_schema=False,
default_response_class=HTMLResponse)
########
# API Routes
########
@api_router.post("/", response_model=schemas.Game, status_code=201) @api_router.post("/", response_model=schemas.Game, status_code=201)
def create_game(game: schemas.GameCreate, db: Session = Depends(get_db)): def create_game(game: schemas.GameCreate, db: Session = Depends(get_db)):
@ -35,6 +42,10 @@ def delete_game(game_id: str, db=Depends(get_db)):
crud.delete_game_by_id(db, int(game_id)) crud.delete_game_by_id(db, int(game_id))
########
# HTML Routes
########
@html_router.get("/create", response_class=HTMLResponse) @html_router.get("/create", response_class=HTMLResponse)
def game_create_html(request: Request, db=Depends(get_db)): def game_create_html(request: Request, db=Depends(get_db)):
players = list_players(db=db) players = list_players(db=db)
@ -55,7 +66,7 @@ def game_create_html(request: Request, db=Depends(get_db)):
# TODO - pagination # TODO - pagination
@html_router.get("/list", response_class=HTMLResponse) @html_router.get("/list")
def games_html(request: Request, db=Depends(get_db)): def games_html(request: Request, db=Depends(get_db)):
games = list_games(db=db) games = list_games(db=db)
return jinja_templates.TemplateResponse( return jinja_templates.TemplateResponse(
@ -64,7 +75,7 @@ def games_html(request: Request, db=Depends(get_db)):
# This must be after the static-path routes, lest it take priority over them # This must be after the static-path routes, lest it take priority over them
@html_router.get("/{game_id}", response_class=HTMLResponse) @html_router.get("/{game_id}")
def game_html(request: Request, game_id: str, db=Depends(get_db)): def game_html(request: Request, game_id: str, db=Depends(get_db)):
game_info = read_game(game_id, db) game_info = read_game(game_id, db)
return jinja_templates.TemplateResponse( return jinja_templates.TemplateResponse(

View File

@ -7,7 +7,14 @@ from ..sql import crud, schemas
from ..sql.database import get_db from ..sql.database import get_db
api_router = APIRouter(prefix="/player", tags=["player"]) api_router = APIRouter(prefix="/player", tags=["player"])
html_router = APIRouter(prefix="/player", include_in_schema=False) html_router = APIRouter(
prefix="/player",
include_in_schema=False,
default_response_class=HTMLResponse)
########
# API Routes
########
@api_router.post("/", response_model=schemas.Player, status_code=201) @api_router.post("/", response_model=schemas.Player, status_code=201)
@ -33,13 +40,23 @@ def delete_player(player_id: str, db=Depends(get_db)):
crud.delete_player_by_id(db, int(player_id)) crud.delete_player_by_id(db, int(player_id))
@html_router.get("/create", response_class=HTMLResponse) ########
# HTML Routes
########
@html_router.get("/create")
def player_create_html(request: Request, db=Depends(get_db)): def player_create_html(request: Request, db=Depends(get_db)):
return jinja_templates.TemplateResponse(request, "players/create.html") return jinja_templates.TemplateResponse(request, "players/create.html")
@html_router.get("/list", response_class=HTMLResponse)
def player_list_html(request: Request, db=Depends(get_db)):
players = list_players(db=db)
return jinja_templates.TemplateResponse(
request, "players/list.html", {"players": players})
# This must be after the static-path routes, lest it take priority over them # This must be after the static-path routes, lest it take priority over them
@html_router.get("/{player_id}", response_class=HTMLResponse) @html_router.get("/{player_id}")
def player_html(request: Request, player_id: str, db=Depends(get_db)): def player_html(request: Request, player_id: str, db=Depends(get_db)):
player_info = read_player(player_id, db) player_info = read_player(player_id, db)
return jinja_templates.TemplateResponse( return jinja_templates.TemplateResponse(

View File

@ -0,0 +1,20 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Players</title>
</head>
<body>
<h1>Players</h1>
<table>
<tr>
<th>Name</th>
</tr>
{% for player in players %}
<tr>
<td><a href="/player/{{ player.id }}">{{ player.name }}</a></td>
</tr>
{% endfor %}
</table>
</body>
</html>