Remove the linked visibility group when deleting a group operation.
This commit is contained in:
parent
31f92c3610
commit
82570bf9db
|
@ -31,6 +31,7 @@
|
||||||
#include "../../../undocommands/label/operationshowlabel.h"
|
#include "../../../undocommands/label/operationshowlabel.h"
|
||||||
#include "../../../undocommands/savetooloptions.h"
|
#include "../../../undocommands/savetooloptions.h"
|
||||||
#include "../../../undocommands/undogroup.h"
|
#include "../../../undocommands/undogroup.h"
|
||||||
|
#include "../../../undocommands/deltool.h"
|
||||||
#include "../vgeometry/vpointf.h"
|
#include "../vgeometry/vpointf.h"
|
||||||
|
|
||||||
const QString VAbstractOperation::TagItem = QStringLiteral("item");
|
const QString VAbstractOperation::TagItem = QStringLiteral("item");
|
||||||
|
@ -619,6 +620,34 @@ void VAbstractOperation::ApplyToolOptions(const QList<quint32> &oldDependencies,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void VAbstractOperation::PerformDelete()
|
||||||
|
{
|
||||||
|
vidtype group = doc->GroupLinkedToTool(m_id);
|
||||||
|
bool deleteGroup = group != null_id;
|
||||||
|
|
||||||
|
qCDebug(vTool, "Begin deleting.");
|
||||||
|
if (deleteGroup)
|
||||||
|
{
|
||||||
|
qApp->getUndoStack()->beginMacro(tr("delete operation"));
|
||||||
|
|
||||||
|
qCDebug(vTool, "Deleting the linked group.");
|
||||||
|
DelGroup *delGroup = new DelGroup(doc, group);
|
||||||
|
connect(delGroup, &DelGroup::UpdateGroups, doc, &VAbstractPattern::UpdateVisiblityGroups);
|
||||||
|
qApp->getUndoStack()->push(delGroup);
|
||||||
|
}
|
||||||
|
|
||||||
|
qCDebug(vTool, "Deleting the tool.");
|
||||||
|
DelTool *delTool = new DelTool(doc, m_id);
|
||||||
|
connect(delTool, &DelTool::NeedFullParsing, doc, &VAbstractPattern::NeedFullParsing);
|
||||||
|
qApp->getUndoStack()->push(delTool);
|
||||||
|
|
||||||
|
if (deleteGroup)
|
||||||
|
{
|
||||||
|
qApp->getUndoStack()->endMacro();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VAbstractOperation::UpdateNamePosition(quint32 id, const QPointF &pos)
|
void VAbstractOperation::UpdateNamePosition(quint32 id, const QPointF &pos)
|
||||||
{
|
{
|
||||||
|
|
|
@ -143,6 +143,7 @@ protected:
|
||||||
virtual void ChangeLabelVisibility(quint32 id, bool visible) override;
|
virtual void ChangeLabelVisibility(quint32 id, bool visible) override;
|
||||||
virtual void ApplyToolOptions(const QList<quint32> &oldDependencies, const QList<quint32> &newDependencies,
|
virtual void ApplyToolOptions(const QList<quint32> &oldDependencies, const QList<quint32> &newDependencies,
|
||||||
const QDomElement &oldDomElement, const QDomElement &newDomElement) override;
|
const QDomElement &oldDomElement, const QDomElement &newDomElement) override;
|
||||||
|
virtual void PerformDelete() override;
|
||||||
|
|
||||||
void UpdateNamePosition(quint32 id, const QPointF &pos);
|
void UpdateNamePosition(quint32 id, const QPointF &pos);
|
||||||
void SaveSourceDestination(QDomElement &tag);
|
void SaveSourceDestination(QDomElement &tag);
|
||||||
|
|
|
@ -224,10 +224,7 @@ void VAbstractTool::DeleteToolWithConfirm(bool ask)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
qCDebug(vTool, "Begin deleting.");
|
PerformDelete();
|
||||||
DelTool *delTool = new DelTool(doc, m_id);
|
|
||||||
connect(delTool, &DelTool::NeedFullParsing, doc, &VAbstractPattern::NeedFullParsing);
|
|
||||||
qApp->getUndoStack()->push(delTool);
|
|
||||||
|
|
||||||
// Throw exception, this will help prevent case when we forget to immediately quit function.
|
// Throw exception, this will help prevent case when we forget to immediately quit function.
|
||||||
VExceptionToolWasDeleted e("Tool was used after deleting.");
|
VExceptionToolWasDeleted e("Tool was used after deleting.");
|
||||||
|
@ -239,6 +236,15 @@ void VAbstractTool::DeleteToolWithConfirm(bool ask)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void VAbstractTool::PerformDelete()
|
||||||
|
{
|
||||||
|
qCDebug(vTool, "Begin deleting.");
|
||||||
|
DelTool *delTool = new DelTool(doc, m_id);
|
||||||
|
connect(delTool, &DelTool::NeedFullParsing, doc, &VAbstractPattern::NeedFullParsing);
|
||||||
|
qApp->getUndoStack()->push(delTool);
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
int VAbstractTool::ConfirmDeletion()
|
int VAbstractTool::ConfirmDeletion()
|
||||||
{
|
{
|
||||||
|
|
|
@ -159,6 +159,7 @@ protected:
|
||||||
*/
|
*/
|
||||||
virtual void RemoveReferens() {}
|
virtual void RemoveReferens() {}
|
||||||
virtual void DeleteToolWithConfirm(bool ask = true);
|
virtual void DeleteToolWithConfirm(bool ask = true);
|
||||||
|
virtual void PerformDelete();
|
||||||
static int ConfirmDeletion();
|
static int ConfirmDeletion();
|
||||||
|
|
||||||
template<typename T>
|
template<typename T>
|
||||||
|
|
Loading…
Reference in New Issue
Block a user