Simplify generating of download context menu.

This commit is contained in:
Florian Bruhin 2014-12-16 14:10:25 +01:00
parent e0271eff34
commit ed013ac3cf

View File

@ -117,28 +117,49 @@ class DownloadView(QListView):
item.open_file() item.open_file()
self.model().remove_item(item) self.model().remove_item(item)
def _get_menu_actions(self, item):
"""Get the available context menu actions for a given DownloadItem.
Args:
item: The DownloadItem to get the actions for, or None.
Return:
A list of either:
- (QAction, callable) tuples.
- (None, None) for a seperator
"""
actions = []
if item is None:
pass
elif item.done:
if item.successful:
actions.append(("Open", item.open_file))
else:
actions.append(("Retry", item.retry))
actions.append(("Remove",
functools.partial(self.model().remove_item, item)))
else:
actions.append(("Cancel", item.cancel))
return actions
@pyqtSlot('QPoint') @pyqtSlot('QPoint')
def show_context_menu(self, point): def show_context_menu(self, point):
"""Show the context menu.""" """Show the context menu."""
index = self.indexAt(point) index = self.indexAt(point)
if not index.isValid(): if index.isValid():
return item = self.model().data(index, downloads.ModelRole.item)
item = self.model().data(index, downloads.ModelRole.item)
self._menu = QMenu(self)
if item.done:
if item.successful:
open_action = self._menu.addAction("Open")
open_action.triggered.connect(item.open_file)
else:
retry_action = self._menu.addAction("Retry")
retry_action.triggered.connect(item.retry)
remove = self._menu.addAction("Remove")
remove.triggered.connect(functools.partial(
self.model().remove_item, item))
else: else:
cancel = self._menu.addAction("Cancel") item = None
cancel.triggered.connect(item.cancel) self._menu = QMenu(self)
self._menu.popup(self.viewport().mapToGlobal(point)) actions = self._get_menu_actions(item)
for (name, handler) in actions:
if name is None and handler is None:
self._menu.addSeparator()
else:
action = self._menu.addAction(name)
action.triggered.connect(handler)
if actions:
self._menu.popup(self.viewport().mapToGlobal(point))
def minimumSizeHint(self): def minimumSizeHint(self):
"""Override minimumSizeHint so the size is correct in a layout.""" """Override minimumSizeHint so the size is correct in a layout."""