Implement context menus in booster, drone & implant views
This commit is contained in:
@@ -23,6 +23,7 @@ import gui.display as d
|
||||
import gui.fittingView as fv
|
||||
import gui.marketBrowser as mb
|
||||
from gui.builtinViewColumns.activityCheckbox import ActivityCheckbox
|
||||
from gui.contextMenu import ContextMenu
|
||||
|
||||
class BoosterView(d.Display):
|
||||
DEFAULT_COLS = ["Activity Checkbox",
|
||||
@@ -35,6 +36,10 @@ class BoosterView(d.Display):
|
||||
self.mainFrame.Bind(mb.ITEM_SELECTED, self.addItem)
|
||||
self.Bind(wx.EVT_LEFT_DCLICK, self.removeItem)
|
||||
self.Bind(wx.EVT_LEFT_DOWN, self.click)
|
||||
if "__WXGTK__" in wx.PlatformInfo:
|
||||
self.Bind(wx.EVT_RIGHT_UP, self.scheduleMenu)
|
||||
else:
|
||||
self.Bind(wx.EVT_RIGHT_DOWN, self.scheduleMenu)
|
||||
|
||||
def fitChanged(self, event):
|
||||
cFit = service.Fit.getInstance()
|
||||
@@ -74,3 +79,17 @@ class BoosterView(d.Display):
|
||||
cFit.toggleBooster(fitID, row)
|
||||
wx.PostEvent(self.mainFrame, fv.FitChanged(fitID=fitID))
|
||||
|
||||
|
||||
def scheduleMenu(self, event):
|
||||
event.Skip()
|
||||
if self.getColumn(event.Position) != self.getColIndex(ActivityCheckbox):
|
||||
wx.CallAfter(self.spawnMenu)
|
||||
|
||||
def spawnMenu(self):
|
||||
sel = self.GetFirstSelected()
|
||||
if sel != -1:
|
||||
cFit = service.Fit.getInstance()
|
||||
fit = cFit.getFit(self.mainFrame.getActiveFit())
|
||||
|
||||
menu = ContextMenu.getMenu((fit.boosters[sel],), "booster")
|
||||
self.PopupMenu(menu)
|
||||
|
||||
@@ -8,7 +8,7 @@ class ItemStats(ContextMenu):
|
||||
self.mainFrame = gui.mainFrame.MainFrame.getInstance()
|
||||
|
||||
def display(self, context, selection):
|
||||
return context in ("item", "ship", "module", "ammo", "skill", "itemSearch")
|
||||
return context in ("item", "ship", "module", "ammo", "skill", "itemSearch", "drone", "implant", "booster")
|
||||
|
||||
def getText(self, context, selection):
|
||||
return "%s stats" % (context.capitalize() if context != "itemSearch" else "Item")
|
||||
|
||||
@@ -24,6 +24,7 @@ import gui.fittingView as fv
|
||||
import gui.marketBrowser as mb
|
||||
import gui.display as d
|
||||
from gui.builtinViewColumns.droneCheckbox import DroneCheckbox
|
||||
from gui.contextMenu import ContextMenu
|
||||
|
||||
class DroneView(d.Display):
|
||||
DEFAULT_COLS = ["Drone Checkbox",
|
||||
@@ -39,6 +40,10 @@ class DroneView(d.Display):
|
||||
self.mainFrame.Bind(mb.ITEM_SELECTED, self.addItem)
|
||||
self.Bind(wx.EVT_LEFT_DCLICK, self.removeItem)
|
||||
self.Bind(wx.EVT_LEFT_DOWN, self.click)
|
||||
if "__WXGTK__" in wx.PlatformInfo:
|
||||
self.Bind(wx.EVT_RIGHT_UP, self.scheduleMenu)
|
||||
else:
|
||||
self.Bind(wx.EVT_RIGHT_DOWN, self.scheduleMenu)
|
||||
|
||||
def fitChanged(self, event):
|
||||
cFit = service.Fit.getInstance()
|
||||
@@ -70,6 +75,7 @@ class DroneView(d.Display):
|
||||
wx.PostEvent(self.mainFrame, fv.FitChanged(fitID=fitID))
|
||||
|
||||
def click(self, event):
|
||||
event.Skip()
|
||||
row, _ = self.HitTest(event.Position)
|
||||
if row != -1:
|
||||
col = self.getColumn(event.Position)
|
||||
@@ -78,3 +84,17 @@ class DroneView(d.Display):
|
||||
cFit = service.Fit.getInstance()
|
||||
cFit.toggleDrone(fitID, row)
|
||||
wx.PostEvent(self.mainFrame, fv.FitChanged(fitID=fitID))
|
||||
|
||||
def scheduleMenu(self, event):
|
||||
event.Skip()
|
||||
if self.getColumn(event.Position) != self.getColIndex(DroneCheckbox):
|
||||
wx.CallAfter(self.spawnMenu)
|
||||
|
||||
def spawnMenu(self):
|
||||
sel = self.GetFirstSelected()
|
||||
if sel != -1:
|
||||
cFit = service.Fit.getInstance()
|
||||
fit = cFit.getFit(self.mainFrame.getActiveFit())
|
||||
|
||||
menu = ContextMenu.getMenu((fit.drones[sel],), "drone")
|
||||
self.PopupMenu(menu)
|
||||
|
||||
@@ -23,6 +23,7 @@ import gui.display as d
|
||||
import gui.fittingView as fv
|
||||
import gui.marketBrowser as mb
|
||||
from gui.builtinViewColumns.activityCheckbox import ActivityCheckbox
|
||||
from gui.contextMenu import ContextMenu
|
||||
|
||||
class ImplantView(d.Display):
|
||||
DEFAULT_COLS = ["Activity Checkbox",
|
||||
@@ -36,6 +37,10 @@ class ImplantView(d.Display):
|
||||
self.Bind(wx.EVT_LEFT_DCLICK, self.removeItem)
|
||||
self.Bind(wx.EVT_KEY_UP, self.kbEvent)
|
||||
self.Bind(wx.EVT_LEFT_DOWN, self.click)
|
||||
if "__WXGTK__" in wx.PlatformInfo:
|
||||
self.Bind(wx.EVT_RIGHT_UP, self.scheduleMenu)
|
||||
else:
|
||||
self.Bind(wx.EVT_RIGHT_DOWN, self.scheduleMenu)
|
||||
|
||||
def kbEvent(self,event):
|
||||
keycode = event.GetKeyCode()
|
||||
@@ -85,3 +90,18 @@ class ImplantView(d.Display):
|
||||
cFit = service.Fit.getInstance()
|
||||
cFit.toggleImplant(fitID, row)
|
||||
wx.PostEvent(self.mainFrame, fv.FitChanged(fitID=fitID))
|
||||
|
||||
def scheduleMenu(self, event):
|
||||
event.Skip()
|
||||
if self.getColumn(event.Position) != self.getColIndex(ActivityCheckbox):
|
||||
wx.CallAfter(self.spawnMenu)
|
||||
|
||||
def spawnMenu(self):
|
||||
sel = self.GetFirstSelected()
|
||||
if sel != -1:
|
||||
cFit = service.Fit.getInstance()
|
||||
fit = cFit.getFit(self.mainFrame.getActiveFit())
|
||||
|
||||
menu = ContextMenu.getMenu((fit.implants[sel],), "implant")
|
||||
self.PopupMenu(menu)
|
||||
|
||||
|
||||
Reference in New Issue
Block a user