diff options
author | Jan Dalheimer <jan@dalheimer.de> | 2013-12-26 22:02:25 +0100 |
---|---|---|
committer | Jan Dalheimer <jan@dalheimer.de> | 2013-12-26 22:02:25 +0100 |
commit | 53db8edb851917809209e4473eef2a66651d6047 (patch) | |
tree | e968580dc51ad9616e3ae518909771ca6568ac87 /CategorizedView.cpp | |
parent | acbbdf319a7378a4029965a52222e7a84c33253f (diff) | |
download | MultiMC-53db8edb851917809209e4473eef2a66651d6047.tar MultiMC-53db8edb851917809209e4473eef2a66651d6047.tar.gz MultiMC-53db8edb851917809209e4473eef2a66651d6047.tar.lz MultiMC-53db8edb851917809209e4473eef2a66651d6047.tar.xz MultiMC-53db8edb851917809209e4473eef2a66651d6047.zip |
Fixing several d&d bugs
Diffstat (limited to 'CategorizedView.cpp')
-rw-r--r-- | CategorizedView.cpp | 26 |
1 files changed, 11 insertions, 15 deletions
diff --git a/CategorizedView.cpp b/CategorizedView.cpp index 780674eb..1860f095 100644 --- a/CategorizedView.cpp +++ b/CategorizedView.cpp @@ -872,6 +872,8 @@ QPair<CategorizedView::Category *, int> CategorizedView::rowDropPos(const QPoint } } + QList<QModelIndex> indices = itemsForCategory(category); + // calculate the internal column int internalColumn = -1; { @@ -912,26 +914,20 @@ QPair<CategorizedView::Category *, int> CategorizedView::rowDropPos(const QPoint { return qMakePair(nullptr, -1); } - } - - QList<QModelIndex> indices = itemsForCategory(category); - - // flaten the internalColumn/internalRow to one row - int categoryRow = 0; - { - for (int i = 0; i < internalRow; ++i) + // this happens if we're in the margin between a one category and another + // categories header + if (internalRow > (indices.size() / itemsPerRow())) { - if ((i + 1) >= internalRow) - { - break; - } - categoryRow += itemsPerRow(); + return qMakePair(nullptr, -1); } - categoryRow += internalColumn; } + // flaten the internalColumn/internalRow to one row + int categoryRow = internalRow * itemsPerRow() + internalColumn; + // this is used if we're past the last item - if (internalColumn >= qMin(itemsPerRow(), indices.size())) + int numItemsInLastRow = indices.size() % itemsPerRow(); + if (internalColumn >= numItemsInLastRow) { return qMakePair(category, indices.last().row() + 1); } |