50 lines
1.5 KiB
Python
50 lines
1.5 KiB
Python
import wx
|
|
from logbook import Logger
|
|
|
|
import eos.db
|
|
from service.fit import Fit
|
|
|
|
|
|
pyfalog = Logger(__name__)
|
|
|
|
|
|
class CalcChangeProjectedDroneStateCommand(wx.Command):
|
|
|
|
def __init__(self, fitID, itemID, state):
|
|
wx.Command.__init__(self, True, 'Change Projected Drone State')
|
|
self.fitID = fitID
|
|
self.itemID = itemID
|
|
self.state = state
|
|
self.savedState = None
|
|
|
|
def Do(self):
|
|
pyfalog.debug('Doing changing of projected drone {} state to {} for fit {}'.format(self.itemID, self.state, self.fitID))
|
|
fit = Fit.getInstance().getFit(self.fitID)
|
|
|
|
drone = next((pd for pd in fit.projectedDrones if pd.itemID == self.itemID), None)
|
|
if drone is None:
|
|
pyfalog.warning('Unable to find projected drone')
|
|
return False
|
|
self.savedState = drone.amountActive > 0
|
|
|
|
if self.state == self.savedState:
|
|
return False
|
|
|
|
if self.state:
|
|
if not drone.canBeApplied(fit):
|
|
pyfalog.warning('Projected drone cannot be applied')
|
|
return False
|
|
drone.amountActive = drone.amount
|
|
else:
|
|
drone.amountActive = 0
|
|
|
|
return True
|
|
|
|
def Undo(self):
|
|
pyfalog.debug('Undoing changing of projected drone {} state to {} for fit {}'.format(self.itemID, self.state, self.fitID))
|
|
cmd = CalcChangeProjectedDroneStateCommand(
|
|
fitID=self.fitID,
|
|
itemID=self.itemID,
|
|
state=self.savedState)
|
|
return cmd.Do()
|