mirror of https://gitlab.com/pamhyr/pamhyr2
Compare commits
No commits in common. "9043b6e2a380e19bcf0dbf914614a13dd071a3ac" and "3a78d6d6f725bffa414e27d2da82994eb1b357dd" have entirely different histories.
9043b6e2a3
...
3a78d6d6f7
|
|
@ -400,16 +400,6 @@ class BoundaryCondition(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for el in self._data:
|
|
||||||
el._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(
|
return len(
|
||||||
list(
|
list(
|
||||||
|
|
|
||||||
|
|
@ -415,16 +415,6 @@ class BoundaryConditionAdisTS(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(self._data)
|
return len(self._data)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -197,16 +197,6 @@ class D90AdisTS(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(self._data)
|
return len(self._data)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -220,16 +220,6 @@ class DIFAdisTS(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(self._data)
|
return len(self._data)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -229,16 +229,6 @@ class BasicHS(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(self._data)
|
return len(self._data)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -327,16 +327,6 @@ class HydraulicStructure(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(self.lst)
|
return len(self.lst)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -374,16 +374,6 @@ class InitialConditions(SQLSubModel):
|
||||||
|
|
||||||
return ok
|
return ok
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(self.data)
|
return len(self.data)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -439,17 +439,6 @@ class LateralContribution(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(
|
return len(
|
||||||
list(
|
list(
|
||||||
|
|
|
||||||
|
|
@ -392,16 +392,6 @@ class LateralContributionAdisTS(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(
|
return len(
|
||||||
list(
|
list(
|
||||||
|
|
|
||||||
|
|
@ -441,16 +441,6 @@ class Pollutants(SQLSubModel):
|
||||||
|
|
||||||
return ok
|
return ok
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def enabled(self):
|
def enabled(self):
|
||||||
return self._enabled
|
return self._enabled
|
||||||
|
|
|
||||||
|
|
@ -375,16 +375,6 @@ class Reservoir(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for d in self._data:
|
|
||||||
d._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def __len__(self):
|
def __len__(self):
|
||||||
return len(self._data)
|
return len(self._data)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -627,52 +627,6 @@ class River(Graph):
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logger_exception(e)
|
logger_exception(e)
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
"""Traversal data and execute modifier fonction if predicate
|
|
||||||
true
|
|
||||||
|
|
||||||
Args:
|
|
||||||
predicate: Function predicate, take current obj and data as input
|
|
||||||
modifier: Function modifier, take current obj and data as input
|
|
||||||
|
|
||||||
Returns:
|
|
||||||
Nothing
|
|
||||||
|
|
||||||
"""
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for obj in self._get_objs_list():
|
|
||||||
obj._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def _get_objs_list(self):
|
|
||||||
objs = (self._nodes + self._edges)
|
|
||||||
objs += [
|
|
||||||
self._boundary_condition,
|
|
||||||
self._initial_conditions,
|
|
||||||
self._lateral_contribution,
|
|
||||||
self._sediment_layers,
|
|
||||||
self._stricklers,
|
|
||||||
self._reservoir,
|
|
||||||
self._hydraulic_structures,
|
|
||||||
self._additional_files,
|
|
||||||
self._rep_lines,
|
|
||||||
self._Output_rk_adists,
|
|
||||||
self._Pollutants,
|
|
||||||
self._InitialConditionsAdisTS,
|
|
||||||
self._BoundaryConditionsAdisTS,
|
|
||||||
self._LateralContributionsAdisTS,
|
|
||||||
self._D90AdisTS, self._DIFAdisTS,
|
|
||||||
]
|
|
||||||
|
|
||||||
for solver in self._parameters:
|
|
||||||
objs.append(self._parameters[solver])
|
|
||||||
|
|
||||||
return objs
|
|
||||||
|
|
||||||
def init_default(self):
|
def init_default(self):
|
||||||
self.init_default_network()
|
self.init_default_network()
|
||||||
self.init_default_sediment()
|
self.init_default_sediment()
|
||||||
|
|
|
||||||
|
|
@ -471,16 +471,6 @@ class SedimentLayer(SQLSubModel):
|
||||||
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
||||||
for layer in self._layers:
|
|
||||||
layer._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
def get(self, index):
|
def get(self, index):
|
||||||
return self.layers[index]
|
return self.layers[index]
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -502,25 +502,3 @@ class Study(SQLModel):
|
||||||
self.status.set_as_read_only()
|
self.status.set_as_read_only()
|
||||||
else:
|
else:
|
||||||
self.status.set_as_editable()
|
self.status.set_as_editable()
|
||||||
|
|
||||||
def duplicate_current_scenario(self):
|
|
||||||
source = self.status.scenario_id
|
|
||||||
new = self.scenarios.new(
|
|
||||||
self.status.scenario.parent
|
|
||||||
)
|
|
||||||
|
|
||||||
new.set_pos(self.status.scenario.x + 100,
|
|
||||||
self.status.scenario.y + 100)
|
|
||||||
|
|
||||||
new.name = self.status.scenario.name + " (copy)"
|
|
||||||
|
|
||||||
self.river._data_traversal(
|
|
||||||
predicate=lambda obj, data: obj._owner_scenario == source,
|
|
||||||
modifier=lambda obj, data: obj.set_owner_scenario(),
|
|
||||||
data={}
|
|
||||||
)
|
|
||||||
|
|
||||||
self.status.scenario = new
|
|
||||||
|
|
||||||
self.status.set_as_editable()
|
|
||||||
return new
|
|
||||||
|
|
|
||||||
|
|
@ -202,7 +202,7 @@ class SQLSubModel(PamhyrID):
|
||||||
self._owner_scenario = self._status.scenario_id
|
self._owner_scenario = self._status.scenario_id
|
||||||
self._status.modified()
|
self._status.modified()
|
||||||
|
|
||||||
def set_owner_scenario(self):
|
def set_owner_scenario_if(self, predicate):
|
||||||
"""Set study status the object owner_scenario to current
|
"""Set study status the object owner_scenario to current
|
||||||
scenario if predicate(scenario_id) is true
|
scenario if predicate(scenario_id) is true
|
||||||
|
|
||||||
|
|
@ -215,8 +215,9 @@ class SQLSubModel(PamhyrID):
|
||||||
if self._status is None:
|
if self._status is None:
|
||||||
return
|
return
|
||||||
|
|
||||||
self._owner_scenario = self._status.scenario_id
|
if predicate(self._owner_scenario):
|
||||||
self._status.modified()
|
self._owner_scenario = self._status.scenario_id
|
||||||
|
self._status.modified()
|
||||||
|
|
||||||
def is_deleted(self):
|
def is_deleted(self):
|
||||||
"""This object is deleted?
|
"""This object is deleted?
|
||||||
|
|
@ -413,22 +414,3 @@ class SQLSubModel(PamhyrID):
|
||||||
save
|
save
|
||||||
"""
|
"""
|
||||||
raise NotImplementedMethodeError(self, self._db_save)
|
raise NotImplementedMethodeError(self, self._db_save)
|
||||||
|
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
"""Traversal data and execute modifier fonction if predicate
|
|
||||||
true
|
|
||||||
|
|
||||||
Args:
|
|
||||||
predicate: Function predicate, take current obj and data as input
|
|
||||||
modifier: Function modifier, take current obj and data as input
|
|
||||||
|
|
||||||
Returns:
|
|
||||||
Nothing
|
|
||||||
|
|
||||||
"""
|
|
||||||
if predicate(self, data):
|
|
||||||
modifier(self, data)
|
|
||||||
|
|
|
||||||
|
|
@ -82,24 +82,20 @@ class PamhyrModelDict(SQLSubModel):
|
||||||
self.set(key, new)
|
self.set(key, new)
|
||||||
return new
|
return new
|
||||||
|
|
||||||
def _data_traversal(self,
|
def rec_set_owner_scenario_if(self, predicate):
|
||||||
predicate=lambda obj, data: True,
|
"""Set study status the object owner_scenario to current
|
||||||
modifier=lambda obj, data: None,
|
scenario if predicate(scenario_id) is true
|
||||||
data={}):
|
|
||||||
"""Traversal data and execute modifier fonction if predicate
|
|
||||||
true
|
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
predicate: Function predicate, take current obj and data as input
|
predicate: Function predicate on owner_scenario id
|
||||||
modifier: Function modifier, take current obj and data as input
|
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
Nothing
|
Nothing
|
||||||
|
|
||||||
"""
|
"""
|
||||||
for key in self._dict:
|
self.set_owner_scenario_if(predicate)
|
||||||
self._dict[key]\
|
|
||||||
._data_traversal(predicate, modifier, data)
|
for k in self._lst:
|
||||||
|
self._dict[key].set_owner_scenario_if(predicate)
|
||||||
|
|
||||||
def new(self, key):
|
def new(self, key):
|
||||||
raise NotImplementedMethodeError(self, self.new)
|
raise NotImplementedMethodeError(self, self.new)
|
||||||
|
|
|
||||||
|
|
@ -85,23 +85,20 @@ class PamhyrModelList(SQLSubModel):
|
||||||
if self._status is not None:
|
if self._status is not None:
|
||||||
self._status.modified()
|
self._status.modified()
|
||||||
|
|
||||||
def _data_traversal(self,
|
def rec_set_owner_scenario_if(self, predicate):
|
||||||
predicate=lambda obj, data: True,
|
"""Set study status the object owner_scenario to current
|
||||||
modifier=lambda obj, data: None,
|
scenario if predicate(scenario_id) is true
|
||||||
data={}):
|
|
||||||
"""Traversal data and execute modifier fonction if predicate
|
|
||||||
true
|
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
predicate: Function predicate, take current obj and data as input
|
predicate: Function predicate on owner_scenario id
|
||||||
modifier: Function modifier, take current obj and data as input
|
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
Nothing
|
Nothing
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
self.set_owner_scenario_if(predicate)
|
||||||
|
|
||||||
for el in self._lst:
|
for el in self._lst:
|
||||||
el._data_traversal(predicate, modifier, data)
|
el.set_owner_scenario_if(predicate)
|
||||||
|
|
||||||
def new(self, index):
|
def new(self, index):
|
||||||
"""Create new elements and add it to list
|
"""Create new elements and add it to list
|
||||||
|
|
@ -213,24 +210,6 @@ class PamhyrModelListWithTab(SQLSubModel):
|
||||||
def _db_save(self, execute, data=None):
|
def _db_save(self, execute, data=None):
|
||||||
raise NotImplementedMethodeError(self, self._db_save)
|
raise NotImplementedMethodeError(self, self._db_save)
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
"""Traversal data and execute modifier fonction if predicate
|
|
||||||
true
|
|
||||||
|
|
||||||
Args:
|
|
||||||
predicate: Function predicate, take current obj and data as input
|
|
||||||
modifier: Function modifier, take current obj and data as input
|
|
||||||
|
|
||||||
Returns:
|
|
||||||
Nothing
|
|
||||||
"""
|
|
||||||
for tab in self._tabs:
|
|
||||||
for el in self._tabs[tab]:
|
|
||||||
el._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
################
|
################
|
||||||
# MODEL METHOD #
|
# MODEL METHOD #
|
||||||
################
|
################
|
||||||
|
|
|
||||||
|
|
@ -90,22 +90,20 @@ class PamhyrModelList(SQLSubModel):
|
||||||
if self._status is not None:
|
if self._status is not None:
|
||||||
self._status.modified()
|
self._status.modified()
|
||||||
|
|
||||||
def _data_traversal(self,
|
def rec_set_owner_scenario_if(self, predicate):
|
||||||
predicate=lambda obj, data: True,
|
"""Set study status the object owner_scenario to current
|
||||||
modifier=lambda obj, data: None,
|
scenario if predicate(scenario_id) is true
|
||||||
data={}):
|
|
||||||
"""Traversal data and execute modifier fonction if predicate
|
|
||||||
true
|
|
||||||
|
|
||||||
Args:
|
Args:
|
||||||
predicate: Function predicate, take current obj and data as input
|
predicate: Function predicate on owner_scenario id
|
||||||
modifier: Function modifier, take current obj and data as input
|
|
||||||
|
|
||||||
Returns:
|
Returns:
|
||||||
Nothing
|
Nothing
|
||||||
"""
|
"""
|
||||||
|
self.set_owner_scenario_if(predicate)
|
||||||
|
|
||||||
for el in self._lst:
|
for el in self._lst:
|
||||||
el._data_traversal(predicate, modifier, data)
|
el.set_owner_scenario_if(predicate)
|
||||||
|
|
||||||
def new(self, index):
|
def new(self, index):
|
||||||
"""Create new elements and add it to list
|
"""Create new elements and add it to list
|
||||||
|
|
@ -226,24 +224,6 @@ class PamhyrModelListWithTab(SQLSubModel):
|
||||||
def _db_save(self, execute, data=None):
|
def _db_save(self, execute, data=None):
|
||||||
raise NotImplementedMethodeError(self, self._db_save)
|
raise NotImplementedMethodeError(self, self._db_save)
|
||||||
|
|
||||||
def _data_traversal(self,
|
|
||||||
predicate=lambda obj, data: True,
|
|
||||||
modifier=lambda obj, data: None,
|
|
||||||
data={}):
|
|
||||||
"""Traversal data and execute modifier fonction if predicate
|
|
||||||
true
|
|
||||||
|
|
||||||
Args:
|
|
||||||
predicate: Function predicate, take current obj and data as input
|
|
||||||
modifier: Function modifier, take current obj and data as input
|
|
||||||
|
|
||||||
Returns:
|
|
||||||
Nothing
|
|
||||||
"""
|
|
||||||
for tab in self._tabs_list:
|
|
||||||
for el in self._tabs[tab]:
|
|
||||||
el._data_traversal(predicate, modifier, data)
|
|
||||||
|
|
||||||
################
|
################
|
||||||
# MODEL METHOD #
|
# MODEL METHOD #
|
||||||
################
|
################
|
||||||
|
|
|
||||||
|
|
@ -133,7 +133,7 @@ class Rubar3(CommandLineSolver):
|
||||||
|
|
||||||
def log_file(self):
|
def log_file(self):
|
||||||
name = self._study.name
|
name = self._study.name
|
||||||
return f"geomac-i.{name}"
|
return f"{name}"
|
||||||
|
|
||||||
def export(self, study, repertory, qlog=None):
|
def export(self, study, repertory, qlog=None):
|
||||||
self._study = study
|
self._study = study
|
||||||
|
|
|
||||||
|
|
@ -57,23 +57,14 @@ class DefaultMenu(AbstractMenu):
|
||||||
class ScenarioMenu(AbstractMenu):
|
class ScenarioMenu(AbstractMenu):
|
||||||
def run(self):
|
def run(self):
|
||||||
item = self._items[0]
|
item = self._items[0]
|
||||||
current_scenario = item.graph._study.status.scenario.id
|
|
||||||
|
|
||||||
select = self._menu.addAction(self._trad["menu_select_scenario"])
|
select = self._menu.addAction(self._trad["menu_select_scenario"])
|
||||||
duplicate = None
|
|
||||||
delete = None
|
|
||||||
|
|
||||||
if item.scenario.id != 0:
|
if item.scenario.id != 0:
|
||||||
delete = self._menu.addAction(self._trad["menu_del_scenario"])
|
delete = self._menu.addAction(self._trad["menu_del_scenario"])
|
||||||
if item.scenario.id == current_scenario:
|
|
||||||
duplicate = self._menu.addAction(
|
|
||||||
self._trad["menu_dup_scenario"]
|
|
||||||
)
|
|
||||||
|
|
||||||
action = self._exec()
|
action = self._exec()
|
||||||
if action == select:
|
if action == select:
|
||||||
self._parent.select_scenario(item)
|
self._parent.select_scenario(item)
|
||||||
elif action == delete:
|
elif item.scenario.id != 0:
|
||||||
self._parent.delete_scenario(item)
|
if action == delete:
|
||||||
elif action == duplicate:
|
self._parent.delete_scenario(item)
|
||||||
self._parent.duplicate_scenario(item)
|
|
||||||
|
|
|
||||||
|
|
@ -459,19 +459,6 @@ class GraphWidget(QGraphicsView):
|
||||||
self.exec_with_waiting_window(fn, "delete_scenario")
|
self.exec_with_waiting_window(fn, "delete_scenario")
|
||||||
self.changeScenario.emit(self.sender())
|
self.changeScenario.emit(self.sender())
|
||||||
|
|
||||||
def duplicate_scenario(self, item):
|
|
||||||
def fn():
|
|
||||||
self._close_other_window()
|
|
||||||
# self._study.save()
|
|
||||||
self._undo.push(
|
|
||||||
DuplicateScenariosCommand(
|
|
||||||
self._study,
|
|
||||||
)
|
|
||||||
)
|
|
||||||
|
|
||||||
self.exec_with_waiting_window(fn, "duplicate_scenario")
|
|
||||||
self.changeScenario.emit(self.sender())
|
|
||||||
|
|
||||||
def _close_other_window(self):
|
def _close_other_window(self):
|
||||||
self.parent\
|
self.parent\
|
||||||
.parent\
|
.parent\
|
||||||
|
|
|
||||||
|
|
@ -80,25 +80,6 @@ class DeleteScenariosCommand(QUndoCommand):
|
||||||
self._scenario.set_as_deleted()
|
self._scenario.set_as_deleted()
|
||||||
|
|
||||||
|
|
||||||
class DuplicateScenariosCommand(QUndoCommand):
|
|
||||||
def __init__(self, study):
|
|
||||||
QUndoCommand.__init__(self)
|
|
||||||
|
|
||||||
self._study = study
|
|
||||||
self._new = None
|
|
||||||
|
|
||||||
def undo(self):
|
|
||||||
self._study.scenarios.delete(self._new.id)
|
|
||||||
self._study.reload_from_scenario(self._new.parent)
|
|
||||||
|
|
||||||
def redo(self):
|
|
||||||
if self._new is None:
|
|
||||||
self._new = self._study.duplicate_current_scenario()
|
|
||||||
else:
|
|
||||||
self._new.set_as_not_deleted()
|
|
||||||
self._study.reload_from_scenario(self._new)
|
|
||||||
|
|
||||||
|
|
||||||
class SetCommand(QUndoCommand):
|
class SetCommand(QUndoCommand):
|
||||||
def __init__(self, scenario, column, new_value):
|
def __init__(self, scenario, column, new_value):
|
||||||
QUndoCommand.__init__(self)
|
QUndoCommand.__init__(self)
|
||||||
|
|
|
||||||
|
|
@ -40,9 +40,6 @@ class ScenariosTranslate(MainTranslate):
|
||||||
self._dict["menu_del_scenario"] = _translate(
|
self._dict["menu_del_scenario"] = _translate(
|
||||||
"Scenarios", "Delete this scenario"
|
"Scenarios", "Delete this scenario"
|
||||||
)
|
)
|
||||||
self._dict["menu_dup_scenario"] = _translate(
|
|
||||||
"Scenarios", "Duplicate this scenario"
|
|
||||||
)
|
|
||||||
|
|
||||||
self._sub_dict["table_headers_scenarios"] = {
|
self._sub_dict["table_headers_scenarios"] = {
|
||||||
# "id": self._dict['id'],
|
# "id": self._dict['id'],
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue