import wx from logbook import Logger import eos.db from service.fit import Fit pyfalog = Logger(__name__) class FitChangeModuleSpoolupCommand(wx.Command): def __init__(self, fitID, position, spoolType, spoolAmount, projected=False): wx.Command.__init__(self, True, 'Change Module Spoolup') self.fitID = fitID self.position = position self.spoolType = spoolType self.spoolAmount = spoolAmount self.projected = projected self.savedSpoolType = None self.savedSpoolAmount = None def Do(self): pyfalog.debug('Doing change of module spoolup at position {} to {} type {} amount on fit {}'.format(self.position, self.spoolType, self.spoolAmount, self.fitID)) fit = Fit.getInstance().getFit(self.fitID) container = fit.modules if not self.projected else fit.projectedModules mod = container[self.position] if mod.isEmpty: pyfalog.warning('Attempt to change spoolup for empty module') return False self.savedSpoolType = mod.spoolType self.savedSpoolAmount = mod.spoolAmount if self.spoolType == self.savedSpoolType and self.spoolAmount == self.savedSpoolAmount: return False mod.spoolType = self.spoolType mod.spoolAmount = self.spoolAmount eos.db.commit() return True def Undo(self): pyfalog.debug('Undoing change of module spoolup at position {} to {} type {} amount on fit {}'.format(self.position, self.spoolType, self.spoolAmount, self.fitID)) cmd = FitChangeModuleSpoolupCommand( fitID=self.fitID, position=self.position, spoolType=self.savedSpoolType, spoolAmount=self.savedSpoolAmount, projected=self.projected) return cmd.Do()