support dragging multiple decks at once

This commit is contained in:
Damien Elmes 2021-01-30 21:25:30 +10:00
parent 49a40e7178
commit 4579740df6

View File

@ -271,6 +271,7 @@ class SidebarTreeView(QTreeView):
self.setUniformRowHeights(True) self.setUniformRowHeights(True)
self.setHeaderHidden(True) self.setHeaderHidden(True)
self.setIndentation(15) self.setIndentation(15)
self.setSelectionMode(QAbstractItemView.SelectionMode.ExtendedSelection)
self.setDragDropMode(QAbstractItemView.InternalMove) self.setDragDropMode(QAbstractItemView.InternalMove)
self.setDragDropOverwriteMode(False) self.setDragDropOverwriteMode(False)
@ -344,7 +345,6 @@ class SidebarTreeView(QTreeView):
model = self.model() model = self.model()
source_items = [model.item_for_index(idx) for idx in self.selectedIndexes()] source_items = [model.item_for_index(idx) for idx in self.selectedIndexes()]
target_item = model.item_for_index(self.indexAt(event.pos())) target_item = model.item_for_index(self.indexAt(event.pos()))
print("drop")
if self.handle_drag_drop(source_items, target_item): if self.handle_drag_drop(source_items, target_item):
event.acceptProposedAction() event.acceptProposedAction()
@ -648,6 +648,13 @@ class SidebarTreeView(QTreeView):
if not m.children(): if not m.children():
return return
# until we support multiple selection, show user that only the current
# item is being operated on by clearing the selection
if idx:
sm = self.selectionModel()
sm.clear()
sm.select(idx, QItemSelectionModel.SelectCurrent | QItemSelectionModel.Rows)
m.exec_(QCursor.pos()) m.exec_(QCursor.pos())
def maybe_add_tree_actions( def maybe_add_tree_actions(