Stricklers: Add to scenarios.

scenarios
Pierre-Antoine Rouby 2024-08-28 10:03:25 +02:00
parent ac32995e01
commit 9ec21d815d
3 changed files with 68 additions and 19 deletions

View File

@ -31,8 +31,10 @@ class Stricklers(SQLSubModel):
comment: str = "", comment: str = "",
minor: float = 35.0, minor: float = 35.0,
medium: float = 15.0, medium: float = 15.0,
status=None): status=None, owner_scenario=-1):
super(Stricklers, self).__init__(id) super(Stricklers, self).__init__(
id=id, owner_scenario=owner_scenario
)
self._status = status self._status = status
self._name = name self._name = name
@ -46,6 +48,7 @@ class Stricklers(SQLSubModel):
execute(f""" execute(f"""
CREATE TABLE stricklers{ext} ( CREATE TABLE stricklers{ext} (
{cls.create_db_add_pamhyr_id()}, {cls.create_db_add_pamhyr_id()},
deleted BOOLEAN NOT NULL DEFAULT FALSE,
name TEXT, name TEXT,
comment TEXT, comment TEXT,
minor REAL NOT NULL, minor REAL NOT NULL,
@ -64,6 +67,13 @@ class Stricklers(SQLSubModel):
if major == minor == "0": if major == minor == "0":
cls._db_update_to_0_1_0(execute, data) cls._db_update_to_0_1_0(execute, data)
if major == "0" and minor == "1":
if release < 2:
execute(
"ALTER TABLE stricklers " +
"ADD COLUMN deleted BOOLEAN NOT NULL DEFAULT FALSE"
)
return cls._update_submodel(execute, version, data) return cls._update_submodel(execute, version, data)
@classmethod @classmethod
@ -89,10 +99,19 @@ class Stricklers(SQLSubModel):
def _db_load(cls, execute, data=None): def _db_load(cls, execute, data=None):
stricklers = [] stricklers = []
status = data["status"] status = data["status"]
scenario = data["scenario"]
loaded = data['loaded_pid']
if scenario is None:
return []
table = execute( table = execute(
"SELECT pamhyr_id, name, comment, minor, medium " + "SELECT pamhyr_id, deleted, " +
"FROM stricklers" "name, comment, minor, medium, scenario " +
"FROM stricklers " +
f"WHERE scenario = {scenario.id} " +
f"AND pamhyr_id NOT IN ({', '.join(map(str, loaded))})"
) )
if table is None: if table is None:
@ -102,32 +121,47 @@ class Stricklers(SQLSubModel):
it = iter(row) it = iter(row)
pid = next(it) pid = next(it)
deleted = (next(it) == 1)
name = next(it) name = next(it)
comment = next(it) comment = next(it)
minor = next(it) minor = next(it)
medium = next(it) medium = next(it)
owner_scenario = next(it)
new = cls( new = cls(
id=pid, id=pid,
name=name, name=name,
comment=comment, comment=comment,
minor=minor, medium=medium, minor=minor, medium=medium,
status=status status=status, owner_scenario=owner_scenario
) )
if deleted:
new.set_as_deleted()
stricklers.append(new) stricklers.append(new)
loaded.add(pid)
data["scenario"] = scenario.parent
stricklers += cls._db_load(execute, data)
data["scenario"] = scenario
return stricklers return stricklers
def _db_save(self, execute, data=None): def _db_save(self, execute, data=None):
if not self.must_be_saved():
return True
execute( execute(
"INSERT INTO " + "INSERT INTO " +
"stricklers(pamhyr_id, name, comment, minor, medium) " + "stricklers(pamhyr_id, deleted, " +
"name, comment, minor, medium, scenario) " +
"VALUES (" + "VALUES (" +
f"{self.pamhyr_id}, " + f"{self.pamhyr_id}, " +
f"{self.is_deleted()}, " +
f"'{self._db_format(self.name)}', " + f"'{self._db_format(self.name)}', " +
f"'{self._db_format(self.comment)}', " + f"'{self._db_format(self.comment)}', " +
f"{float(self.minor)}, {float(self.medium)}" + f"{float(self.minor)}, {float(self.medium)}, " +
f"{self._status.scenario_id}"
")" ")"
) )
@ -148,6 +182,7 @@ class Stricklers(SQLSubModel):
@name.setter @name.setter
def name(self, name): def name(self, name):
self._name = name self._name = name
self.modified()
@property @property
def comment(self): def comment(self):
@ -156,6 +191,7 @@ class Stricklers(SQLSubModel):
@comment.setter @comment.setter
def comment(self, comment): def comment(self, comment):
self._comment = comment self._comment = comment
self.modified()
@property @property
def minor(self): def minor(self):
@ -164,6 +200,7 @@ class Stricklers(SQLSubModel):
@minor.setter @minor.setter
def minor(self, minor): def minor(self, minor):
self._minor = float(minor) self._minor = float(minor)
self.modified()
@property @property
def medium(self): def medium(self):
@ -172,3 +209,4 @@ class Stricklers(SQLSubModel):
@medium.setter @medium.setter
def medium(self, medium): def medium(self, medium):
self._medium = float(medium) self._medium = float(medium)
self.modified()

View File

@ -18,7 +18,7 @@
from tools import trace, timer from tools import trace, timer
from Model.Tools.PamhyrList import PamhyrModelList from Model.Tools.PamhyrListExt import PamhyrModelList
from Model.Stricklers.Stricklers import Stricklers from Model.Stricklers.Stricklers import Stricklers
@ -47,7 +47,10 @@ class StricklersList(PamhyrModelList):
return new return new
def _db_save(self, execute, data=None): def _db_save(self, execute, data=None):
execute("DELETE FROM stricklers") execute(
"DELETE FROM stricklers " +
f"WHERE scenario = {self._status.scenario_id}"
)
objs = self._lst objs = self._lst
return self._save_submodel(execute, objs, data) return self._save_submodel(execute, objs, data)
@ -57,8 +60,12 @@ class StricklersList(PamhyrModelList):
return self.lst return self.lst
def new(self, index): def new(self, index):
s = Stricklers(status=self._status) s = Stricklers(
status=self._status,
owner_scenario=self._status.scenario_id
)
self.insert(index, s) self.insert(index, s)
self.modified()
return s return s
@timer @timer
@ -73,5 +80,4 @@ class StricklersList(PamhyrModelList):
reverse=reverse, reverse=reverse,
) )
if self._status is not None: self.modified()
self._status.modified()

View File

@ -108,7 +108,8 @@ class AddCommand(QUndoCommand):
if self._new is None: if self._new is None:
self._new = self._data.new(self._index) self._new = self._data.new(self._index)
else: else:
self._data.insert(self._index, self._new) self._data.undelete([self._new])
# self._data.insert(self._index, self._new)
class DelCommand(QUndoCommand): class DelCommand(QUndoCommand):
@ -120,15 +121,14 @@ class DelCommand(QUndoCommand):
self._el = [] self._el = []
for row in rows: for row in rows:
self._el.append((row, self._data.get(row))) self._el.append(self._data.get(row))
self._el.sort() self._el.sort()
def undo(self): def undo(self):
for row, el in self._el: self._data.undelete(self._el)
self._data.insert(row, el)
def redo(self): def redo(self):
self._data.delete_i(self._rows) self._data.delete(self._el)
class SortCommand(QUndoCommand): class SortCommand(QUndoCommand):
@ -167,10 +167,15 @@ class PasteCommand(QUndoCommand):
self._row = row self._row = row
self._el = deepcopy(el) self._el = deepcopy(el)
self._el.reverse() self._el.reverse()
self._done = False
def undo(self): def undo(self):
self._data.delete(self._el) self._data.delete(self._el)
def redo(self): def redo(self):
if self._done:
for el in self._el:
self._data.undelete([el])
else:
for el in self._el: for el in self._el:
self._data.insert(self._row, el) self._data.insert(self._row, el)