edit/delete player/war/campaign/round
This commit is contained in:
parent
dc854b4065
commit
185733b5d4
9 changed files with 363 additions and 58 deletions
|
|
@ -1,6 +1,7 @@
|
|||
from pathlib import Path
|
||||
import json
|
||||
import shutil
|
||||
from datetime import datetime
|
||||
|
||||
from warchron.model.player import Player
|
||||
from warchron.model.war import War
|
||||
|
|
@ -60,8 +61,8 @@ class Model:
|
|||
def get_player(self, id):
|
||||
return self.players[id]
|
||||
|
||||
def update_player(self, id, name):
|
||||
player = self.get_player(id)
|
||||
def update_player(self, player_id: str, *, name: str):
|
||||
player = self.get_player(player_id)
|
||||
player.set_name(name)
|
||||
|
||||
def delete_player(self, id):
|
||||
|
|
@ -70,20 +71,41 @@ class Model:
|
|||
def get_all_players(self) -> list[Player]:
|
||||
return list(self.players.values())
|
||||
|
||||
def add_war(self, name) -> War:
|
||||
war = War(name)
|
||||
def get_default_war_values(self) -> dict:
|
||||
return {
|
||||
"year": datetime.now().year
|
||||
}
|
||||
|
||||
def add_war(self, name: str, year: int) -> War:
|
||||
war = War(name, year)
|
||||
self.wars[war.id] = war
|
||||
return war
|
||||
|
||||
def get_war(self, id) -> War:
|
||||
return self.wars[id]
|
||||
|
||||
def get_war_by_campaign(self, campaign_id: str) -> War:
|
||||
for war in self.wars.values():
|
||||
for camp in war.campaigns:
|
||||
if camp.id == campaign_id:
|
||||
return war
|
||||
raise KeyError(f"Campaign {campaign_id} not found in any War")
|
||||
|
||||
def update_war(self, war_id: str, *, name: str, year: int):
|
||||
war = self.get_war(war_id)
|
||||
war.set_name(name)
|
||||
war.set_year(year)
|
||||
|
||||
def get_all_wars(self) -> list[War]:
|
||||
return list(self.wars.values())
|
||||
|
||||
def add_campaign(self, war_id: str, name: str) -> Campaign:
|
||||
|
||||
def get_default_campaign_values(self, war_id: str) -> dict:
|
||||
war = self.get_war(war_id)
|
||||
return war.add_campaign(name)
|
||||
return war.get_default_campaign_values()
|
||||
|
||||
def add_campaign(self, war_id: str, name: str, month: int) -> Campaign:
|
||||
war = self.get_war(war_id)
|
||||
return war.add_campaign(name, month)
|
||||
|
||||
def get_campaign(self, campaign_id) -> Campaign:
|
||||
for war in self.wars.values():
|
||||
|
|
@ -92,6 +114,17 @@ class Model:
|
|||
return campaign
|
||||
raise KeyError("Campaign not found")
|
||||
|
||||
def get_campaign_by_round(self, round_id: str) -> Campaign:
|
||||
for war in self.wars.values():
|
||||
camp = war.get_campaign_by_round(round_id)
|
||||
if camp is not None:
|
||||
return camp
|
||||
raise KeyError(f"Round {round_id} not found")
|
||||
|
||||
def update_campaign(self, campaign_id: str, *, name: str, month: int):
|
||||
war = self.get_war_by_campaign(campaign_id)
|
||||
war.update_campaign(campaign_id, name=name, month=month)
|
||||
|
||||
def add_round(self, campaign_id: str) -> Round:
|
||||
campaign = self.get_campaign(campaign_id)
|
||||
return campaign.add_round()
|
||||
|
|
@ -102,4 +135,18 @@ class Model:
|
|||
for rnd in campaign.rounds:
|
||||
if rnd.id == round_id:
|
||||
return rnd
|
||||
raise KeyError("Round not found")
|
||||
raise KeyError("Round not found")
|
||||
|
||||
def remove_player(self, player_id: str):
|
||||
del self.players[player_id]
|
||||
|
||||
def remove_war(self, war_id: str):
|
||||
del self.wars[war_id]
|
||||
|
||||
def remove_campaign(self, campaign_id: str):
|
||||
war = self.get_war_by_campaign(campaign_id)
|
||||
war.remove_campaign(campaign_id)
|
||||
|
||||
def remove_round(self, round_id: str):
|
||||
camp = self.get_campaign_by_round(round_id)
|
||||
camp.remove_round(round_id)
|
||||
Loading…
Add table
Add a link
Reference in a new issue