mirror of https://gitlab.com/pamhyr/pamhyr2
Stricklers: Add to scenarios.
parent
ac32995e01
commit
9ec21d815d
|
|
@ -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()
|
||||||
|
|
|
||||||
|
|
@ -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()
|
|
||||||
|
|
|
||||||
|
|
@ -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)
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue