Player List (and default responseClass)
This commit is contained in:
parent
e7831948b2
commit
7e54b9dc65
@ -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(
|
||||||
|
@ -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(
|
||||||
|
@ -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(
|
||||||
|
20
app/templates/players/list.html
Normal file
20
app/templates/players/list.html
Normal 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>
|
Loading…
x
Reference in New Issue
Block a user