2016-04-03 21:55:12 -04:00
|
|
|
#include "FractoriumPch.h"
|
|
|
|
#include "LibraryTreeWidget.h"
|
|
|
|
#include "Fractorium.h"
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Set a pointer to the main window.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="f">Pointer to the main Fractorium object</param>
|
|
|
|
void LibraryTreeWidget::SetMainWindow(Fractorium* f)
|
|
|
|
{
|
|
|
|
m_Fractorium = f;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Process the drop event to allow for moving items around inside of the tree.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="de">Pointer to the QDropEvent object</param>
|
|
|
|
void LibraryTreeWidget::dropEvent(QDropEvent* de)
|
|
|
|
{
|
|
|
|
QModelIndex droppedIndex = indexAt(de->pos());
|
2016-12-05 22:04:33 -05:00
|
|
|
auto items = selectionModel()->selectedRows();
|
2016-04-03 21:55:12 -04:00
|
|
|
|
|
|
|
if (!droppedIndex.isValid())//Don't process drop because it's outside of the droppable area.
|
|
|
|
{
|
|
|
|
de->ignore();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else if (!items.empty())//Actually do the drop and move the item to a new location.
|
|
|
|
{
|
2017-03-02 23:04:47 -05:00
|
|
|
// get the list of the items that are about to be dragged
|
|
|
|
int i, row = droppedIndex.row();
|
2016-04-03 21:55:12 -04:00
|
|
|
DropIndicatorPosition dp = dropIndicatorPosition();
|
2017-03-02 23:04:47 -05:00
|
|
|
QList<QTreeWidgetItem*> dragItems = selectedItems();
|
2016-04-03 21:55:12 -04:00
|
|
|
|
|
|
|
if (dp == QAbstractItemView::BelowItem)
|
|
|
|
row++;
|
|
|
|
|
2017-03-02 23:04:47 -05:00
|
|
|
auto itemat = this->itemFromIndex(droppedIndex);
|
|
|
|
QTreeWidget::dropEvent(de);//This internally changes the order of the items.
|
|
|
|
|
|
|
|
//Qt has a long standing major bug that rearranges the order of disjoint selections when
|
|
|
|
//The drop location is in between the disjoint regions.
|
|
|
|
//This is an attempt to correct for that bug by removing the dropped items, then re-inserting them
|
|
|
|
//in the order they were selected.
|
|
|
|
//This bug remains present as of Qt 5.8: https://bugreports.qt.io/browse/QTBUG-45320
|
|
|
|
if (auto top = topLevelItem(0))
|
|
|
|
{
|
|
|
|
if (itemat)
|
|
|
|
{
|
|
|
|
auto offsetitem = this->indexFromItem(itemat);
|
|
|
|
|
|
|
|
if (dp == QAbstractItemView::BelowItem)
|
|
|
|
{
|
|
|
|
auto itemrow = offsetitem.row() + 1;
|
|
|
|
|
|
|
|
for (i = 0; i < dragItems.size(); i++)
|
|
|
|
{
|
|
|
|
if (itemrow < top->childCount())
|
|
|
|
top->takeChild(itemrow);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < dragItems.size(); i++)
|
|
|
|
{
|
|
|
|
auto offset = i + itemrow;
|
|
|
|
|
|
|
|
if (offset <= top->childCount())
|
|
|
|
top->insertChild(offset, dragItems[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
auto itemrow = offsetitem.row();//Will be at least 1 if dropped above it.
|
|
|
|
auto offset = itemrow;
|
|
|
|
|
2017-03-04 10:46:28 -05:00
|
|
|
for (i = 0; i < dragItems.size() && offset > 0; i++)
|
2017-03-02 23:04:47 -05:00
|
|
|
{
|
|
|
|
offset--;
|
|
|
|
|
|
|
|
if (offset < top->childCount())
|
|
|
|
top->takeChild(offset);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < dragItems.size(); i++)
|
|
|
|
{
|
|
|
|
if (offset <= top->childCount())
|
|
|
|
top->insertChild(offset, dragItems[i]);
|
|
|
|
|
|
|
|
offset++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-03-04 10:46:28 -05:00
|
|
|
m_Fractorium->m_Controller->MoveLibraryItems(items, row);
|
2016-04-03 21:55:12 -04:00
|
|
|
}
|
|
|
|
}
|