New undo command SaveDetailOptions.
--HG-- branch : feature
This commit is contained in:
parent
154c2c0708
commit
c23a93037c
|
@ -45,34 +45,16 @@ VAbstractNode::VAbstractNode(VPattern *doc, VContainer *data, const quint32 &id,
|
||||||
void VAbstractNode::DeleteNode()
|
void VAbstractNode::DeleteNode()
|
||||||
{
|
{
|
||||||
if (_referens <= 1)
|
if (_referens <= 1)
|
||||||
{
|
|
||||||
//remove from xml file
|
|
||||||
QDomElement domElement = doc->elementById(QString().setNum(id));
|
|
||||||
if (domElement.isElement())
|
|
||||||
{
|
|
||||||
QDomNode element = domElement.parentNode();
|
|
||||||
if (element.isNull() == false)
|
|
||||||
{
|
|
||||||
if (element.isElement())
|
|
||||||
{
|
{
|
||||||
RemoveReferens();//deincrement referens
|
RemoveReferens();//deincrement referens
|
||||||
element.removeChild(domElement);//remove form file
|
|
||||||
emit toolhaveChange();//set enabled save button
|
|
||||||
}
|
}
|
||||||
else
|
}
|
||||||
|
|
||||||
|
void VAbstractNode::RestoreNode()
|
||||||
|
{
|
||||||
|
if (_referens <= 1)
|
||||||
{
|
{
|
||||||
qDebug()<<"parent isn't element"<<Q_FUNC_INFO;
|
RestoreReferens();
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
qDebug()<<"parent isNull"<<Q_FUNC_INFO;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
qDebug()<<"Can't get element by id form file = "<<id<<Q_FUNC_INFO;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -113,3 +95,29 @@ void VAbstractNode::decrementReferens()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void VAbstractNode::RemoveReferens()
|
||||||
|
{
|
||||||
|
if (idTool != 0)
|
||||||
|
{
|
||||||
|
doc->DecrementReferens(idTool);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
doc->DecrementReferens(idNode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void VAbstractNode::RestoreReferens()
|
||||||
|
{
|
||||||
|
if (idTool != 0)
|
||||||
|
{
|
||||||
|
doc->IncrementReferens(idTool);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
doc->IncrementReferens(idNode);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -53,6 +53,7 @@ public:
|
||||||
static const QString AttrIdObject;
|
static const QString AttrIdObject;
|
||||||
static const QString AttrIdTool;
|
static const QString AttrIdTool;
|
||||||
virtual void DeleteNode();
|
virtual void DeleteNode();
|
||||||
|
virtual void RestoreNode();
|
||||||
protected:
|
protected:
|
||||||
/**
|
/**
|
||||||
* @brief idNodenode id.
|
* @brief idNodenode id.
|
||||||
|
@ -71,6 +72,8 @@ protected:
|
||||||
* @brief decrementReferens decrement reference for all parent objects.
|
* @brief decrementReferens decrement reference for all parent objects.
|
||||||
*/
|
*/
|
||||||
virtual void decrementReferens();
|
virtual void decrementReferens();
|
||||||
|
virtual void RemoveReferens();
|
||||||
|
virtual void RestoreReferens();
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // VABSTRACTNODE_H
|
#endif // VABSTRACTNODE_H
|
||||||
|
|
|
@ -87,6 +87,15 @@ void VNodeArc::DeleteNode()
|
||||||
this->setVisible(false);
|
this->setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VNodeArc::RestoreNode()
|
||||||
|
{
|
||||||
|
if (this->isVisible() == false)
|
||||||
|
{
|
||||||
|
VAbstractNode::RestoreNode();
|
||||||
|
this->setVisible(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VNodeArc::FullUpdateFromFile()
|
void VNodeArc::FullUpdateFromFile()
|
||||||
{
|
{
|
||||||
|
|
|
@ -73,6 +73,7 @@ public:
|
||||||
* @brief DeleteNode delete node from detail.
|
* @brief DeleteNode delete node from detail.
|
||||||
*/
|
*/
|
||||||
virtual void DeleteNode();
|
virtual void DeleteNode();
|
||||||
|
virtual void RestoreNode();
|
||||||
public slots:
|
public slots:
|
||||||
/**
|
/**
|
||||||
* @brief FullUpdateFromFile update tool data form file.
|
* @brief FullUpdateFromFile update tool data form file.
|
||||||
|
|
|
@ -100,6 +100,15 @@ void VNodePoint::DeleteNode()
|
||||||
this->setVisible(false);
|
this->setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VNodePoint::RestoreNode()
|
||||||
|
{
|
||||||
|
if (this->isVisible() == false)
|
||||||
|
{
|
||||||
|
VAbstractNode::RestoreNode();
|
||||||
|
this->setVisible(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VNodePoint::FullUpdateFromFile()
|
void VNodePoint::FullUpdateFromFile()
|
||||||
{
|
{
|
||||||
|
|
|
@ -77,6 +77,7 @@ public:
|
||||||
* @brief DeleteNode delete node from detail.
|
* @brief DeleteNode delete node from detail.
|
||||||
*/
|
*/
|
||||||
virtual void DeleteNode();
|
virtual void DeleteNode();
|
||||||
|
virtual void RestoreNode();
|
||||||
public slots:
|
public slots:
|
||||||
/**
|
/**
|
||||||
* @brief FullUpdateFromFile update tool data form file.
|
* @brief FullUpdateFromFile update tool data form file.
|
||||||
|
|
|
@ -91,6 +91,15 @@ void VNodeSpline::DeleteNode()
|
||||||
this->setVisible(false);
|
this->setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VNodeSpline::RestoreNode()
|
||||||
|
{
|
||||||
|
if (this->isVisible() == false)
|
||||||
|
{
|
||||||
|
VAbstractNode::RestoreNode();
|
||||||
|
this->setVisible(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VNodeSpline::FullUpdateFromFile()
|
void VNodeSpline::FullUpdateFromFile()
|
||||||
{
|
{
|
||||||
|
|
|
@ -73,6 +73,7 @@ public:
|
||||||
* @brief DeleteNode delete node from detail.
|
* @brief DeleteNode delete node from detail.
|
||||||
*/
|
*/
|
||||||
virtual void DeleteNode();
|
virtual void DeleteNode();
|
||||||
|
virtual void RestoreNode();
|
||||||
public slots:
|
public slots:
|
||||||
/**
|
/**
|
||||||
* @brief FullUpdateFromFile update tool data form file.
|
* @brief FullUpdateFromFile update tool data form file.
|
||||||
|
|
|
@ -94,6 +94,15 @@ void VNodeSplinePath::DeleteNode()
|
||||||
this->setVisible(false);
|
this->setVisible(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VNodeSplinePath::RestoreNode()
|
||||||
|
{
|
||||||
|
if (this->isVisible() == false)
|
||||||
|
{
|
||||||
|
VAbstractNode::RestoreNode();
|
||||||
|
this->setVisible(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VNodeSplinePath::FullUpdateFromFile()
|
void VNodeSplinePath::FullUpdateFromFile()
|
||||||
{
|
{
|
||||||
|
|
|
@ -73,6 +73,7 @@ public:
|
||||||
* @brief DeleteNode delete node from detail.
|
* @brief DeleteNode delete node from detail.
|
||||||
*/
|
*/
|
||||||
virtual void DeleteNode();
|
virtual void DeleteNode();
|
||||||
|
virtual void RestoreNode();
|
||||||
public slots:
|
public slots:
|
||||||
/**
|
/**
|
||||||
* @brief FullUpdateFromFile update tool data form file.
|
* @brief FullUpdateFromFile update tool data form file.
|
||||||
|
|
|
@ -202,18 +202,6 @@ QPointF VAbstractTool::addVector(const QPointF &p, const QPointF &p1, const QPoi
|
||||||
return QPointF (p.x() + (p2.x() - p1.x()) * k, p.y() + (p2.y() - p1.y()) * k);
|
return QPointF (p.x() + (p2.x() - p1.x()) * k, p.y() + (p2.y() - p1.y()) * k);
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
|
||||||
void VAbstractTool::RemoveAllChild(QDomElement &domElement)
|
|
||||||
{
|
|
||||||
if ( domElement.hasChildNodes() )
|
|
||||||
{
|
|
||||||
while ( domElement.childNodes().length() >= 1 )
|
|
||||||
{
|
|
||||||
domElement.removeChild( domElement.firstChild() );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VAbstractTool::DeleteTool(QGraphicsItem *tool)
|
void VAbstractTool::DeleteTool(QGraphicsItem *tool)
|
||||||
{
|
{
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
#include "vdatatool.h"
|
#include "vdatatool.h"
|
||||||
|
|
||||||
class VPattern;
|
class VPattern;
|
||||||
|
class QDomElement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief The VAbstractTool abstract class for all tools.
|
* @brief The VAbstractTool abstract class for all tools.
|
||||||
|
@ -202,11 +203,6 @@ protected:
|
||||||
* @brief RemoveReferens decrement value of reference.
|
* @brief RemoveReferens decrement value of reference.
|
||||||
*/
|
*/
|
||||||
virtual void RemoveReferens(){}
|
virtual void RemoveReferens(){}
|
||||||
/**
|
|
||||||
* @brief RemoveAllChild remove all child from file.
|
|
||||||
* @param domElement tag in xml tree.
|
|
||||||
*/
|
|
||||||
void RemoveAllChild(QDomElement &domElement);
|
|
||||||
/**
|
/**
|
||||||
* @brief DeleteTool full delete object form scene and file.
|
* @brief DeleteTool full delete object form scene and file.
|
||||||
* @param tool tool
|
* @param tool tool
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
#include <QGraphicsSceneMouseEvent>
|
#include <QGraphicsSceneMouseEvent>
|
||||||
#include <QMenu>
|
#include <QMenu>
|
||||||
#include <QGraphicsView>
|
#include <QGraphicsView>
|
||||||
|
#include "../undocommands/savedetailoptions.h"
|
||||||
|
|
||||||
const QString VToolDetail::TagName = QStringLiteral("detail");
|
const QString VToolDetail::TagName = QStringLiteral("detail");
|
||||||
const QString VToolDetail::TagNode = QStringLiteral("node");
|
const QString VToolDetail::TagNode = QStringLiteral("node");
|
||||||
|
@ -246,37 +247,16 @@ void VToolDetail::FullUpdateFromFile()
|
||||||
void VToolDetail::FullUpdateFromGuiOk(int result)
|
void VToolDetail::FullUpdateFromGuiOk(int result)
|
||||||
{
|
{
|
||||||
if (result == QDialog::Accepted)
|
if (result == QDialog::Accepted)
|
||||||
{
|
|
||||||
QDomElement domElement = doc->elementById(QString().setNum(id));
|
|
||||||
if (domElement.isElement())
|
|
||||||
{
|
{
|
||||||
SCASSERT(dialog != nullptr);
|
SCASSERT(dialog != nullptr);
|
||||||
DialogDetail *dialogTool = qobject_cast<DialogDetail*>(dialog);
|
DialogDetail *dialogTool = qobject_cast<DialogDetail*>(dialog);
|
||||||
SCASSERT(dialogTool != nullptr);
|
SCASSERT(dialogTool != nullptr);
|
||||||
VDetail det = dialogTool->getDetails();
|
VDetail newDet = dialogTool->getDetails();
|
||||||
doc->SetAttribute(domElement, AttrName, det.getName());
|
VDetail oldDet = VAbstractTool::data.GetDetail(id);
|
||||||
doc->SetAttribute(domElement, AttrSupplement, QString().setNum(det.getSeamAllowance()));
|
|
||||||
doc->SetAttribute(domElement, AttrClosed, QString().setNum(det.getClosed()));
|
SaveDetailOptions *saveCommand = new SaveDetailOptions(oldDet, newDet, doc, id, this->scene());
|
||||||
doc->SetAttribute(domElement, AttrWidth, QString().setNum(det.getWidth()));
|
connect(saveCommand, &SaveDetailOptions::NeedLiteParsing, doc, &VPattern::LiteParseTree);
|
||||||
RemoveAllChild(domElement);
|
qApp->getUndoStack()->push(saveCommand);
|
||||||
for (ptrdiff_t i = 0; i < det.CountNode(); ++i)
|
|
||||||
{
|
|
||||||
AddNode(domElement, det.at(i));
|
|
||||||
}
|
|
||||||
VDetail detail = VAbstractTool::data.GetDetail(id);
|
|
||||||
QList<quint32> list = detail.Missing(det);
|
|
||||||
QHash<quint32, VDataTool*>* tools = doc->getTools();
|
|
||||||
if (list.size()>0)
|
|
||||||
{
|
|
||||||
for (qint32 i = 0; i < list.size(); ++i)
|
|
||||||
{
|
|
||||||
VAbstractNode *node = qobject_cast<VAbstractNode *>(tools->value(list.at(i)));
|
|
||||||
node->DeleteNode();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
emit LiteUpdateTree();
|
|
||||||
emit toolhaveChange();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
delete dialog;
|
delete dialog;
|
||||||
dialog = nullptr;
|
dialog = nullptr;
|
||||||
|
@ -298,7 +278,7 @@ void VToolDetail::AddToFile()
|
||||||
|
|
||||||
for (ptrdiff_t i = 0; i < detail.CountNode(); ++i)
|
for (ptrdiff_t i = 0; i < detail.CountNode(); ++i)
|
||||||
{
|
{
|
||||||
AddNode(domElement, detail.at(i));
|
AddNode(doc, domElement, detail.at(i));
|
||||||
}
|
}
|
||||||
|
|
||||||
QDomElement element;
|
QDomElement element;
|
||||||
|
@ -320,10 +300,10 @@ void VToolDetail::RefreshDataInFile()
|
||||||
doc->SetAttribute(domElement, AttrSupplement, QString().setNum(det.getSeamAllowance()));
|
doc->SetAttribute(domElement, AttrSupplement, QString().setNum(det.getSeamAllowance()));
|
||||||
doc->SetAttribute(domElement, AttrClosed, QString().setNum(det.getClosed()));
|
doc->SetAttribute(domElement, AttrClosed, QString().setNum(det.getClosed()));
|
||||||
doc->SetAttribute(domElement, AttrWidth, QString().setNum(det.getWidth()));
|
doc->SetAttribute(domElement, AttrWidth, QString().setNum(det.getWidth()));
|
||||||
RemoveAllChild(domElement);
|
doc->RemoveAllChild(domElement);
|
||||||
for (ptrdiff_t i = 0; i < det.CountNode(); ++i)
|
for (ptrdiff_t i = 0; i < det.CountNode(); ++i)
|
||||||
{
|
{
|
||||||
AddNode(domElement, det.at(i));
|
AddNode(doc, domElement, det.at(i));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -432,7 +412,7 @@ void VToolDetail::RemoveReferens()
|
||||||
}
|
}
|
||||||
|
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
void VToolDetail::AddNode(QDomElement &domElement, const VNodeDetail &node)
|
void VToolDetail::AddNode(VPattern *doc, QDomElement &domElement, const VNodeDetail &node)
|
||||||
{
|
{
|
||||||
QDomElement nod = doc->createElement(TagNode);
|
QDomElement nod = doc->createElement(TagNode);
|
||||||
|
|
||||||
|
|
|
@ -112,6 +112,13 @@ public:
|
||||||
* @brief Remove full delete detail.
|
* @brief Remove full delete detail.
|
||||||
*/
|
*/
|
||||||
void Remove();
|
void Remove();
|
||||||
|
/**
|
||||||
|
* @brief AddNode add node to the file.
|
||||||
|
* @param dom document container
|
||||||
|
* @param domElement tag in xml tree.
|
||||||
|
* @param node node of detail.
|
||||||
|
*/
|
||||||
|
static void AddNode(VPattern *doc, QDomElement &domElement, const VNodeDetail &node);
|
||||||
public slots:
|
public slots:
|
||||||
/**
|
/**
|
||||||
* @brief FullUpdateFromFile update tool data form file.
|
* @brief FullUpdateFromFile update tool data form file.
|
||||||
|
@ -171,12 +178,6 @@ private:
|
||||||
* @brief RefreshGeometry refresh item on scene.
|
* @brief RefreshGeometry refresh item on scene.
|
||||||
*/
|
*/
|
||||||
void RefreshGeometry ();
|
void RefreshGeometry ();
|
||||||
/**
|
|
||||||
* @brief AddNode add node to the file.
|
|
||||||
* @param domElement tag in xml tree.
|
|
||||||
* @param node node of detail.
|
|
||||||
*/
|
|
||||||
void AddNode(QDomElement &domElement, const VNodeDetail &node);
|
|
||||||
template <typename Tool>
|
template <typename Tool>
|
||||||
/**
|
/**
|
||||||
* @brief InitTool initial node item on scene
|
* @brief InitTool initial node item on scene
|
||||||
|
|
139
src/app/undocommands/savedetailoptions.cpp
Normal file
139
src/app/undocommands/savedetailoptions.cpp
Normal file
|
@ -0,0 +1,139 @@
|
||||||
|
/************************************************************************
|
||||||
|
**
|
||||||
|
** @file savedetailoptions.cpp
|
||||||
|
** @author Roman Telezhynskyi <dismine(at)gmail.com>
|
||||||
|
** @date 12 6, 2014
|
||||||
|
**
|
||||||
|
** @brief
|
||||||
|
** @copyright
|
||||||
|
** This source code is part of the Valentine project, a pattern making
|
||||||
|
** program, whose allow create and modeling patterns of clothing.
|
||||||
|
** Copyright (C) 2014 Valentina project
|
||||||
|
** <https://bitbucket.org/dismine/valentina> All Rights Reserved.
|
||||||
|
**
|
||||||
|
** Valentina is free software: you can redistribute it and/or modify
|
||||||
|
** it under the terms of the GNU General Public License as published by
|
||||||
|
** the Free Software Foundation, either version 3 of the License, or
|
||||||
|
** (at your option) any later version.
|
||||||
|
**
|
||||||
|
** Valentina is distributed in the hope that it will be useful,
|
||||||
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
** GNU General Public License for more details.
|
||||||
|
**
|
||||||
|
** You should have received a copy of the GNU General Public License
|
||||||
|
** along with Valentina. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
**
|
||||||
|
*************************************************************************/
|
||||||
|
|
||||||
|
#include "savedetailoptions.h"
|
||||||
|
#include "undocommands.h"
|
||||||
|
#include "../tools/nodeDetails/vabstractnode.h"
|
||||||
|
#include <QGraphicsView>
|
||||||
|
|
||||||
|
SaveDetailOptions::SaveDetailOptions(const VDetail &oldDet, const VDetail &newDet, VPattern *doc, const quint32 &id,
|
||||||
|
QGraphicsScene *scene, QUndoCommand *parent)
|
||||||
|
: QObject(), QUndoCommand(parent), oldDet(oldDet), newDet(newDet), doc(doc), detId(id), scene(scene)
|
||||||
|
{
|
||||||
|
setText(tr("Save detail option"));
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
SaveDetailOptions::~SaveDetailOptions()
|
||||||
|
{}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void SaveDetailOptions::undo()
|
||||||
|
{
|
||||||
|
QDomElement domElement = doc->elementById(QString().setNum(detId));
|
||||||
|
if (domElement.isElement())
|
||||||
|
{
|
||||||
|
doc->SetAttribute(domElement, VAbstractTool::AttrName, oldDet.getName());
|
||||||
|
doc->SetAttribute(domElement, VToolDetail::AttrSupplement, QString().setNum(oldDet.getSeamAllowance()));
|
||||||
|
doc->SetAttribute(domElement, VToolDetail::AttrClosed, QString().setNum(oldDet.getClosed()));
|
||||||
|
doc->SetAttribute(domElement, VToolDetail::AttrWidth, QString().setNum(oldDet.getWidth()));
|
||||||
|
doc->RemoveAllChild(domElement);
|
||||||
|
for (ptrdiff_t i = 0; i < oldDet.CountNode(); ++i)
|
||||||
|
{
|
||||||
|
VToolDetail::AddNode(doc, domElement, oldDet.at(i));
|
||||||
|
}
|
||||||
|
QVector<VNodeDetail> nodes = oldDet.getNodes();
|
||||||
|
QHash<quint32, VDataTool*>* tools = doc->getTools();
|
||||||
|
if (nodes.size()>0)
|
||||||
|
{
|
||||||
|
for (qint32 i = 0; i < nodes.size(); ++i)
|
||||||
|
{
|
||||||
|
VAbstractNode *node = qobject_cast<VAbstractNode *>(tools->value(nodes.at(i).getId()));
|
||||||
|
node->RestoreNode();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
emit NeedLiteParsing();
|
||||||
|
|
||||||
|
QList<QGraphicsView*> list = scene->views();
|
||||||
|
VAbstractTool::NewSceneRect(scene, list[0]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qDebug()<<"Can't find detail with id ="<< detId << Q_FUNC_INFO;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
void SaveDetailOptions::redo()
|
||||||
|
{
|
||||||
|
QDomElement domElement = doc->elementById(QString().setNum(detId));
|
||||||
|
if (domElement.isElement())
|
||||||
|
{
|
||||||
|
doc->SetAttribute(domElement, VAbstractTool::AttrName, newDet.getName());
|
||||||
|
doc->SetAttribute(domElement, VToolDetail::AttrSupplement, QString().setNum(newDet.getSeamAllowance()));
|
||||||
|
doc->SetAttribute(domElement, VToolDetail::AttrClosed, QString().setNum(newDet.getClosed()));
|
||||||
|
doc->SetAttribute(domElement, VToolDetail::AttrWidth, QString().setNum(newDet.getWidth()));
|
||||||
|
doc->RemoveAllChild(domElement);
|
||||||
|
for (ptrdiff_t i = 0; i < newDet.CountNode(); ++i)
|
||||||
|
{
|
||||||
|
VToolDetail::AddNode(doc, domElement, newDet.at(i));
|
||||||
|
}
|
||||||
|
QList<quint32> list = oldDet.Missing(newDet);
|
||||||
|
QHash<quint32, VDataTool*>* tools = doc->getTools();
|
||||||
|
if (list.size()>0)
|
||||||
|
{
|
||||||
|
for (qint32 i = 0; i < list.size(); ++i)
|
||||||
|
{
|
||||||
|
VAbstractNode *node = qobject_cast<VAbstractNode *>(tools->value(list.at(i)));
|
||||||
|
node->DeleteNode();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
emit NeedLiteParsing();
|
||||||
|
|
||||||
|
QList<QGraphicsView*> listV = scene->views();
|
||||||
|
VAbstractTool::NewSceneRect(scene, listV[0]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
qDebug()<<"Can't find detail with id ="<< detId << Q_FUNC_INFO;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
bool SaveDetailOptions::mergeWith(const QUndoCommand *command)
|
||||||
|
{
|
||||||
|
const SaveDetailOptions *saveCommand = static_cast<const SaveDetailOptions *>(command);
|
||||||
|
SCASSERT(saveCommand != nullptr);
|
||||||
|
const quint32 id = saveCommand->getDetId();
|
||||||
|
|
||||||
|
if (id != detId)
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
newDet = saveCommand->getNewDet();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
int SaveDetailOptions::id() const
|
||||||
|
{
|
||||||
|
return static_cast<int>(UndoCommand::SaveDetailOptions);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
75
src/app/undocommands/savedetailoptions.h
Normal file
75
src/app/undocommands/savedetailoptions.h
Normal file
|
@ -0,0 +1,75 @@
|
||||||
|
/************************************************************************
|
||||||
|
**
|
||||||
|
** @file savedetailoptions.h
|
||||||
|
** @author Roman Telezhynskyi <dismine(at)gmail.com>
|
||||||
|
** @date 12 6, 2014
|
||||||
|
**
|
||||||
|
** @brief
|
||||||
|
** @copyright
|
||||||
|
** This source code is part of the Valentine project, a pattern making
|
||||||
|
** program, whose allow create and modeling patterns of clothing.
|
||||||
|
** Copyright (C) 2014 Valentina project
|
||||||
|
** <https://bitbucket.org/dismine/valentina> All Rights Reserved.
|
||||||
|
**
|
||||||
|
** Valentina is free software: you can redistribute it and/or modify
|
||||||
|
** it under the terms of the GNU General Public License as published by
|
||||||
|
** the Free Software Foundation, either version 3 of the License, or
|
||||||
|
** (at your option) any later version.
|
||||||
|
**
|
||||||
|
** Valentina is distributed in the hope that it will be useful,
|
||||||
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
** GNU General Public License for more details.
|
||||||
|
**
|
||||||
|
** You should have received a copy of the GNU General Public License
|
||||||
|
** along with Valentina. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
**
|
||||||
|
*************************************************************************/
|
||||||
|
|
||||||
|
#ifndef SAVEDETAILOPTIONS_H
|
||||||
|
#define SAVEDETAILOPTIONS_H
|
||||||
|
|
||||||
|
#include <QUndoCommand>
|
||||||
|
#include <QDomElement>
|
||||||
|
#include "../tools/vtooldetail.h"
|
||||||
|
|
||||||
|
class VPattern;
|
||||||
|
class QGraphicsScene;
|
||||||
|
|
||||||
|
class SaveDetailOptions : public QObject, public QUndoCommand
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
public:
|
||||||
|
SaveDetailOptions(const VDetail &oldDet, const VDetail &newDet, VPattern *doc, const quint32 &id,
|
||||||
|
QGraphicsScene *scene, QUndoCommand *parent = 0);
|
||||||
|
virtual ~SaveDetailOptions();
|
||||||
|
virtual void undo();
|
||||||
|
virtual void redo();
|
||||||
|
virtual bool mergeWith(const QUndoCommand *command);
|
||||||
|
virtual int id() const;
|
||||||
|
quint32 getDetId() const;
|
||||||
|
VDetail getNewDet() const;
|
||||||
|
signals:
|
||||||
|
void NeedLiteParsing();
|
||||||
|
private:
|
||||||
|
Q_DISABLE_COPY(SaveDetailOptions)
|
||||||
|
const VDetail oldDet;
|
||||||
|
VDetail newDet;
|
||||||
|
VPattern *doc;
|
||||||
|
const quint32 detId;
|
||||||
|
QGraphicsScene *scene;
|
||||||
|
};
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
inline quint32 SaveDetailOptions::getDetId() const
|
||||||
|
{
|
||||||
|
return detId;
|
||||||
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
inline VDetail SaveDetailOptions::getNewDet() const
|
||||||
|
{
|
||||||
|
return newDet;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // SAVEDETAILOPTIONS_H
|
|
@ -78,16 +78,16 @@ void SaveToolOptions::redo()
|
||||||
//---------------------------------------------------------------------------------------------------------------------
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
bool SaveToolOptions::mergeWith(const QUndoCommand *command)
|
bool SaveToolOptions::mergeWith(const QUndoCommand *command)
|
||||||
{
|
{
|
||||||
const SaveToolOptions *moveCommand = static_cast<const SaveToolOptions *>(command);
|
const SaveToolOptions *saveCommand = static_cast<const SaveToolOptions *>(command);
|
||||||
SCASSERT(moveCommand != nullptr);
|
SCASSERT(saveCommand != nullptr);
|
||||||
const quint32 id = moveCommand->getToolId();
|
const quint32 id = saveCommand->getToolId();
|
||||||
|
|
||||||
if (id != toolId)
|
if (id != toolId)
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
newXml = moveCommand->getNewXml();
|
newXml = saveCommand->getNewXml();
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,7 +34,8 @@ enum class UndoCommand: char { AddPatternPiece,
|
||||||
MoveSpline,
|
MoveSpline,
|
||||||
MoveSplinePath,
|
MoveSplinePath,
|
||||||
MoveSPoint,
|
MoveSPoint,
|
||||||
SaveToolOptions
|
SaveToolOptions,
|
||||||
|
SaveDetailOptions
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif // UNDOCOMMANDS_H
|
#endif // UNDOCOMMANDS_H
|
||||||
|
|
|
@ -5,7 +5,8 @@ HEADERS += \
|
||||||
undocommands/movespline.h \
|
undocommands/movespline.h \
|
||||||
undocommands/movesplinepath.h \
|
undocommands/movesplinepath.h \
|
||||||
undocommands/savetooloptions.h \
|
undocommands/savetooloptions.h \
|
||||||
undocommands/undocommands.h
|
undocommands/undocommands.h \
|
||||||
|
undocommands/savedetailoptions.h
|
||||||
|
|
||||||
|
|
||||||
SOURCES += \
|
SOURCES += \
|
||||||
|
@ -14,5 +15,6 @@ SOURCES += \
|
||||||
undocommands/movespoint.cpp \
|
undocommands/movespoint.cpp \
|
||||||
undocommands/movespline.cpp \
|
undocommands/movespline.cpp \
|
||||||
undocommands/movesplinepath.cpp \
|
undocommands/movesplinepath.cpp \
|
||||||
undocommands/savetooloptions.cpp
|
undocommands/savetooloptions.cpp \
|
||||||
|
undocommands/savedetailoptions.cpp
|
||||||
|
|
||||||
|
|
|
@ -527,3 +527,19 @@ void VDomDocument::setTagText(const QString &tag, const QString &text)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//---------------------------------------------------------------------------------------------------------------------
|
||||||
|
/**
|
||||||
|
* @brief RemoveAllChild remove all child from file.
|
||||||
|
* @param domElement tag in xml tree.
|
||||||
|
*/
|
||||||
|
void VDomDocument::RemoveAllChild(QDomElement &domElement)
|
||||||
|
{
|
||||||
|
if ( domElement.hasChildNodes() )
|
||||||
|
{
|
||||||
|
while ( domElement.childNodes().length() >= 1 )
|
||||||
|
{
|
||||||
|
domElement.removeChild( domElement.firstChild() );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -146,6 +146,7 @@ public:
|
||||||
QString Major() const;
|
QString Major() const;
|
||||||
QString Minor() const;
|
QString Minor() const;
|
||||||
QString Patch() const;
|
QString Patch() const;
|
||||||
|
static void RemoveAllChild(QDomElement &domElement);
|
||||||
protected:
|
protected:
|
||||||
/**
|
/**
|
||||||
* @brief data container with data.
|
* @brief data container with data.
|
||||||
|
|
Loading…
Reference in New Issue
Block a user