feat(ui): add main menu navbar and join game functionality #35

Merged
lq64 merged 2 commits from feat/30-mainmenu-navbar into main 2025-11-04 12:43:09 +01:00
13 changed files with 111 additions and 14 deletions
Showing only changes of commit 8eec1fd38f - Show all commits

View File

@@ -111,7 +111,10 @@ class IngameController @Inject()(
cardIdOpt match {
case Some(cardId) =>
val result = Try {
g.playCard(g.getUserSession(request.user.id), cardId.toInt)
val session = g.getUserSession(request.user.id)
session.lock.lock()
g.playCard(session, cardId.toInt)
session.lock.unlock()
}
if (result.isSuccess) {
NoContent
@@ -146,9 +149,15 @@ class IngameController @Inject()(
val result = Try {
cardIdOpt match {
case Some(cardId) if cardId == "skip" =>
g.playDogCard(g.getUserSession(request.user.id), -1)
val session = g.getUserSession(request.user.id)
session.lock.lock()
g.playDogCard(session, -1)
session.lock.unlock()
case Some(cardId) =>
g.playDogCard(g.getUserSession(request.user.id), cardId.toInt)
val session = g.getUserSession(request.user.id)
session.lock.lock()
g.playDogCard(session, cardId.toInt)
session.lock.unlock()
case None =>
throw new IllegalArgumentException("cardId parameter is missing")
}
@@ -184,7 +193,10 @@ class IngameController @Inject()(
trumpOpt match {
case Some(trump) =>
val result = Try {
g.selectTrump(g.getUserSession(request.user.id), trump.toInt)
val session = g.getUserSession(request.user.id)
session.lock.lock()
g.selectTrump(session, trump.toInt)
session.lock.unlock()
}
if (result.isSuccess) {
NoContent
@@ -216,7 +228,10 @@ class IngameController @Inject()(
tieOpt match {
case Some(tie) =>
val result = Try {
val session = g.getUserSession(request.user.id)
session.lock.lock()
g.selectTie(g.getUserSession(request.user.id), tie.toInt)
session.lock.unlock()
}
if (result.isSuccess) {
NoContent

View File

@@ -111,6 +111,7 @@ class GameLobby private(
if (!PlayerUtil.canPlayCard(card, getRound, getTrick, player)) {
throw new CantPlayCardException("You can't play this card!")
}
userSession.resetCanInteract()
logic.playerInputLogic.receivedCard(card)
}
@@ -132,6 +133,7 @@ class GameLobby private(
}
val hand = getHand(player)
val card = hand.cards(cardIndex)
userSession.resetCanInteract()
logic.playerInputLogic.receivedDog(Some(card))
}
@@ -144,6 +146,7 @@ class GameLobby private(
val player = getPlayerInteractable(userSession, InteractionType.TrumpSuit)
val trumpSuits = Suit.values.toList
val selectedTrump = trumpSuits(trumpIndex)
userSession.resetCanInteract()
logic.playerInputLogic.receivedTrumpSuit(selectedTrump)
}
@@ -154,6 +157,7 @@ class GameLobby private(
*/
def selectTie(userSession: UserSession, tieNumber: Int): Unit = {
val player = getPlayerInteractable(userSession, InteractionType.TieChoice)
userSession.resetCanInteract()
logic.playerTieLogic.receivedTieBreakerCard(tieNumber)
}

View File

@@ -28,4 +28,8 @@ class UserSession(user: User, val host: Boolean) extends PlayerSession {
override def name: String = user.name
def resetCanInteract(): Unit = {
canInteract = None
}
}