Enable drag and drop of terminal tree widget item

This commit is contained in:
joshua
2021-04-09 14:16:22 +02:00
parent d3ad490b84
commit 171e95fb17
5 changed files with 107 additions and 19 deletions

View File

@@ -48,6 +48,7 @@ class TerminalStrip : public QObject
QString comment() const {return m_data.m_comment;} QString comment() const {return m_data.m_comment;}
void setDescription(const QString &description); void setDescription(const QString &description);
QString description() const {return m_data.m_description;} QString description() const {return m_data.m_description;}
QUuid uuid() const {return m_data.m_uuid;}
bool addTerminal(Element *terminal); bool addTerminal(Element *terminal);
bool removeTerminal(Element *terminal); bool removeTerminal(Element *terminal);

View File

@@ -20,6 +20,8 @@
#include "../properties/propertiesinterface.h" #include "../properties/propertiesinterface.h"
#include <QUuid>
class TerminalStripData : public PropertiesInterface class TerminalStripData : public PropertiesInterface
{ {
friend class TerminalStrip; friend class TerminalStrip;
@@ -39,6 +41,7 @@ class TerminalStripData : public PropertiesInterface
m_name, m_name,
m_comment, m_comment,
m_description; m_description;
QUuid m_uuid = QUuid::createUuid();
}; };

View File

@@ -24,6 +24,7 @@
#include "../qetgraphicsitem/terminalelement.h" #include "../qetgraphicsitem/terminalelement.h"
#include "../UndoCommand/addterminalstripcommand.h" #include "../UndoCommand/addterminalstripcommand.h"
#include "terminalstriptreewidget.h" #include "terminalstriptreewidget.h"
#include "../../qeticons.h"
#include <QTreeWidgetItem> #include <QTreeWidgetItem>
@@ -65,7 +66,7 @@ void TerminalStripEditor::buildTree()
new QTreeWidgetItem(ui->m_terminal_strip_tw, strl, TerminalStripTreeWidget::Root); new QTreeWidgetItem(ui->m_terminal_strip_tw, strl, TerminalStripTreeWidget::Root);
QStringList ftstrl(tr("Bornes indépendante")); QStringList ftstrl(tr("Bornes indépendante"));
new QTreeWidgetItem(ui->m_terminal_strip_tw, ftstrl, TerminalStripTreeWidget::FreeTerminalSection); new QTreeWidgetItem(ui->m_terminal_strip_tw, ftstrl, TerminalStripTreeWidget::FreeTerminal);
auto ts_vector = m_project->terminalStrip(); auto ts_vector = m_project->terminalStrip();
std::sort(ts_vector.begin(), ts_vector.end(), [](TerminalStrip *a, TerminalStrip *b) { std::sort(ts_vector.begin(), ts_vector.end(), [](TerminalStrip *a, TerminalStrip *b) {
@@ -106,7 +107,7 @@ QTreeWidgetItem* TerminalStripEditor::addTerminalStrip(TerminalStrip *terminal_s
} }
if (!inst_qtwi) { if (!inst_qtwi) {
QStringList inst_strl{installation_str}; QStringList inst_strl{installation_str};
inst_qtwi = new QTreeWidgetItem(root_item, inst_strl, TerminalStripTreeWidget::Inst); inst_qtwi = new QTreeWidgetItem(root_item, inst_strl, TerminalStripTreeWidget::Installation);
} }
//Check if location already exist //Check if location already exist
@@ -122,12 +123,14 @@ QTreeWidgetItem* TerminalStripEditor::addTerminalStrip(TerminalStrip *terminal_s
} }
if (!loc_qtwi) { if (!loc_qtwi) {
QStringList loc_strl{location_str}; QStringList loc_strl{location_str};
loc_qtwi = new QTreeWidgetItem(inst_qtwi, loc_strl, TerminalStripTreeWidget::Loc); loc_qtwi = new QTreeWidgetItem(inst_qtwi, loc_strl, TerminalStripTreeWidget::Location);
} }
//Add the terminal strip //Add the terminal strip
QStringList name{terminal_strip->name()}; QStringList name{terminal_strip->name()};
auto item = new QTreeWidgetItem(loc_qtwi, name, TerminalStripTreeWidget::Strip); auto item = new QTreeWidgetItem(loc_qtwi, name, TerminalStripTreeWidget::Strip);
item->setData(0, TerminalStripTreeWidget::UUID_USER_ROLE, terminal_strip->uuid());
item->setIcon(0, QET::Icons::TerminalStrip);
m_H_item_strip.insert(item, terminal_strip); m_H_item_strip.insert(item, terminal_strip);
return item; return item;
} }
@@ -156,8 +159,9 @@ void TerminalStripEditor::addFreeTerminal()
for (const auto terminal : qAsConst(vector_)) for (const auto terminal : qAsConst(vector_))
{ {
QStringList strl{terminal->actualLabel()}; QStringList strl{terminal->actualLabel()};
auto item = new QTreeWidgetItem(free_terminal_item, strl, TerminalStripTreeWidget::FreeTerminal); auto item = new QTreeWidgetItem(free_terminal_item, strl, TerminalStripTreeWidget::Terminal);
item->setData(0, TerminalStripTreeWidget::UUID_USER_ROLE, terminal->uuid().toString()); item->setData(0, TerminalStripTreeWidget::UUID_USER_ROLE, terminal->uuid().toString());
item->setIcon(0, QET::Icons::ElementTerminal);
} }
} }
@@ -174,11 +178,11 @@ void TerminalStripEditor::on_m_add_terminal_strip_pb_clicked()
if (item->type() == TerminalStripTreeWidget::Strip) { if (item->type() == TerminalStripTreeWidget::Strip) {
item = item->parent(); item = item->parent();
} }
if (item->type() == TerminalStripTreeWidget::Loc) { if (item->type() == TerminalStripTreeWidget::Location) {
dialog->setLocation(item->data(0, Qt::DisplayRole).toString()); dialog->setLocation(item->data(0, Qt::DisplayRole).toString());
item = item->parent(); item = item->parent();
} }
if (item->type() == TerminalStripTreeWidget::Inst) { if (item->type() == TerminalStripTreeWidget::Installation) {
dialog->setInstallation(item->data(0, Qt::DisplayRole).toString()); dialog->setInstallation(item->data(0, Qt::DisplayRole).toString());
} }
} }

View File

@@ -1,4 +1,4 @@
/* /*
Copyright 2006-2021 The QElectroTech Team Copyright 2006-2021 The QElectroTech Team
This file is part of QElectroTech. This file is part of QElectroTech.
@@ -31,7 +31,7 @@ TerminalStripTreeWidget::TerminalStripTreeWidget(QWidget *parent) :
QStringList TerminalStripTreeWidget::mimeTypes() const QStringList TerminalStripTreeWidget::mimeTypes() const
{ {
QStringList strl(QStringLiteral("application/x-qet-terminal-strip-tree-item")); QStringList strl(QStringLiteral("application/x-qet-terminal-strip-tree-terminal-uuid"));
return strl; return strl;
} }
@@ -43,13 +43,13 @@ void TerminalStripTreeWidget::startDrag(Qt::DropActions supportedActions)
auto item = currentItem(); auto item = currentItem();
if (!item || if (!item ||
item->type() != TerminalStripTreeWidget::FreeTerminal) { item->type() != TerminalStripTreeWidget::Terminal) {
return; return;
} }
QDrag drag(this); QDrag drag(this);
auto mime_data = new QMimeData(); auto mime_data = new QMimeData();
mime_data->setData("application/x-qet-terminal-strip-tree-item", item->data(0, UUID_USER_ROLE).toString().toLatin1()); mime_data->setData("application/x-qet-terminal-strip-tree-terminal-uuid", item->data(0, UUID_USER_ROLE).toString().toLatin1());
drag.setMimeData(mime_data); drag.setMimeData(mime_data);
drag.setPixmap(QET::Icons::ElementTerminal.pixmap(16,16)); drag.setPixmap(QET::Icons::ElementTerminal.pixmap(16,16));
@@ -58,20 +58,81 @@ void TerminalStripTreeWidget::startDrag(Qt::DropActions supportedActions)
void TerminalStripTreeWidget::dragMoveEvent(QDragMoveEvent *event) void TerminalStripTreeWidget::dragMoveEvent(QDragMoveEvent *event)
{ {
auto strl = event->mimeData()->formats();
if (strl.size() != 1 ||
strl.first() != "application/x-qet-terminal-strip-tree-terminal-uuid") {
event->ignore();
return;
}
//Accepted move are :
//free terminal to terminal strip
//terminal strip to another terminal strip
//terminal strip to free terminal
//All other other move is ignored
QTreeWidget::dragMoveEvent(event); QTreeWidget::dragMoveEvent(event);
auto item = itemAt(event->pos()); auto overred_item = itemAt(event->pos());
auto dragged_item = currentItem();
if (!overred_item ||
!dragged_item ||
!dragged_item->parent()) {
return;
}
//Ignore the event by default, we confirm it bellow if needed.
event->ignore();
if (item && //Move terminal
item->type() == TerminalStripTreeWidget::Strip) { if (dragged_item->parent()->type() == FreeTerminal && //From free to strip
overred_item->type() == Strip) {
event->accept(); event->accept();
} else { }
event->ignore(); else if (dragged_item->parent()->type() == Strip) //From strip to ...
{
if (overred_item->type() == FreeTerminal) { //Free terminal
event->accept();
} else if (overred_item->type() == Strip && //Another strip
dragged_item->parent() != overred_item) {
event->accept();
}
} }
} }
void TerminalStripTreeWidget::dropEvent(QDropEvent *event) void TerminalStripTreeWidget::dropEvent(QDropEvent *event)
{} {
auto overred_item = itemAt(event->pos());
auto dragged_item = currentItem();
if (!overred_item ||
!dragged_item ||
!dragged_item->parent()) {
return;
}
dragged_item->parent()->removeChild(dragged_item);
overred_item->addChild(dragged_item);
//Move terminal
if (dragged_item->parent()->type() == FreeTerminal && //From free to strip
overred_item->type() == Strip) {
emit terminalAddedToStrip(QUuid::fromString(dragged_item->data(0, UUID_USER_ROLE).toString()),
QUuid::fromString(overred_item->data(0, UUID_USER_ROLE).toString()));
}
else if (dragged_item->parent()->type() == Strip) //From strip to ...
{
if (overred_item->type() == FreeTerminal) //Free terminal
{
emit terminalRemovedFromStrip(QUuid::fromString(dragged_item->data(0, UUID_USER_ROLE).toString()),
QUuid::fromString(overred_item->data(0, UUID_USER_ROLE).toString()));
}
else if (overred_item->type() == Strip && //Another strip
dragged_item->parent() != overred_item)
{
emit terminalMovedFromStripToStrip(QUuid::fromString(dragged_item->data(0, UUID_USER_ROLE).toString()),
QUuid::fromString(dragged_item->parent()->data(0, UUID_USER_ROLE).toString()),
QUuid::fromString(overred_item->data(0, UUID_USER_ROLE).toString()));
}
}
}
Qt::DropActions TerminalStripTreeWidget::supportedDropActions() const { Qt::DropActions TerminalStripTreeWidget::supportedDropActions() const {
return Qt::MoveAction; return Qt::MoveAction;

View File

@@ -19,6 +19,7 @@
#define TERMINALSTRIPTREEWIDGET_H #define TERMINALSTRIPTREEWIDGET_H
#include <QTreeWidget> #include <QTreeWidget>
#include <QUuid>
/** /**
* @brief The TerminalStripTreeWidget class * @brief The TerminalStripTreeWidget class
@@ -30,16 +31,34 @@ class TerminalStripTreeWidget : public QTreeWidget
public : public :
enum TreeWidgetType{ enum TreeWidgetType{
Root, Root,
Terminal,
FreeTerminal, FreeTerminal,
FreeTerminalSection, Installation,
Inst, Location,
Loc,
Strip Strip
}; };
//Role used for data in QTreeWidgetItem //Role used for data in QTreeWidgetItem
static int UUID_USER_ROLE; static int UUID_USER_ROLE;
signals:
/**
* @brief terminalAddedToStrip
* Signal emited when a terminal is moved from free terminal to a terminals trip
*/
void terminalAddedToStrip(QUuid terminal_uuid, QUuid strip_uuid);
/**
* @brief terminalMovedFromStripToStrip
* Signam emitted when a terminal is moved from from a terminal stip to another one
*/
void terminalMovedFromStripToStrip(QUuid terminal_uuid, QUuid old_strip_uuid, QUuid new_strip_uuid);
/**
* @brief terminalRemovedFromStrip
* Signal emitted when a terminal is moved from a terminal strip to free terminal
*/
void terminalRemovedFromStrip(QUuid terminal_uuid, QUuid old_strip_uuid);
public: public:
TerminalStripTreeWidget(QWidget *parent = nullptr); TerminalStripTreeWidget(QWidget *parent = nullptr);