Added node delete

Added undo change button

--HG--
branch : XML Editor
This commit is contained in:
Patrick Proy 2014-05-18 21:42:36 +02:00
parent e1c3f418e5
commit 99818c3d28
3 changed files with 441 additions and 97 deletions

View File

@ -53,11 +53,9 @@ DialogPatternXmlEdit::DialogPatternXmlEdit(QWidget *parent, VPattern *xmldoc)
ui->treeView_main->setWindowTitle("XML");
//TODO warning: use of old-style cast [-Wold-style-cast]
rootNode = (QStandardItem*) xmlmodel->invisibleRootItem();
rootNode = xmlmodel->invisibleRootItem();
//TODO warning: conversion to 'qint16 {aka short int}' from 'int' may alter its value [-Wconversion]
qint16 drawnum=xmldoc->elementsByTagName("draw").size();
int drawnum=xmldoc->elementsByTagName("draw").size();
rootBases = new VXMLTreeElement*[drawnum+1];
rootBasesNum=1;
rootBases[0]=new VXMLTreeElement("Valentina", VXMLTreeElement::TypeRoot, root, false);
@ -87,10 +85,133 @@ DialogPatternXmlEdit::DialogPatternXmlEdit(QWidget *parent, VPattern *xmldoc)
connect(ui->pushButton_Remove_attribute, &QPushButton::clicked,
this, &DialogPatternXmlEdit::ButtonDeleteAttributeClicked);
connect(ui->pushButton_Add_son, &QPushButton::clicked, this, &DialogPatternXmlEdit::ButtonAddSonClicked);
connect(ui->pushButton_Add_attribute, &QPushButton::clicked, this,
&DialogPatternXmlEdit::ButtonAddAttributeClicked);
connect(ui->pushButton_Apply_Changes, &QPushButton::clicked, this,
&DialogPatternXmlEdit::ButtonApplyChangesClicked);
connect(ui->pushButton_Add_attribute, &QPushButton::clicked,
this, &DialogPatternXmlEdit::ButtonAddAttributeClicked);
connect(ui->pushButton_Apply_Changes, &QPushButton::clicked,
this, &DialogPatternXmlEdit::ButtonApplyChangesClicked);
connect(ui->pushButton_Undo_Last_Change, &QPushButton::clicked, this, &DialogPatternXmlEdit::ButtonUndoLastChange);
connect(ui->pushButton_Remove_Node, &QPushButton::clicked, this, &DialogPatternXmlEdit::ButtonDeleteNode);
}
//---------------------------------------------------------------------------------------------------------------------
void DialogPatternXmlEdit::ButtonDeleteNode()
{
ChangesStackElement* newstack;
// TODO : maybe assert functions here
if (this->currentNodeEdited == nullptr)
{
return;
}
if (this->currentNodeEdited->GetelementType() != VXMLTreeElement::TypeNode)
{
return;
}
if (this->currentNodeEditedStatus != 0)
{
if (this->currentNodeEditedStatus == DialogPatternXmlEdit::ChangeTypeDelete)
{ // Change already done ??? ignore...
return;
}
if (this->currentNodeEditedStatus == DialogPatternXmlEdit::ChangeTypeAdd)
{ // Attribute was previously added, just undo the change
if ( this->UndoChange(this->currentNodeEditedStack) == false )
{ // Error in undo... warn user
QMessageBox::warning(this, tr("No changes"), tr("Cannot delete previously created node"));
return;
}
this->ClearEditData();
return;
}
if (this->currentNodeEditedStatus == DialogPatternXmlEdit::ChangeTypeModify)
{ // Node was edited : remove change then continue to delete node
this->UndoChange(this->currentNodeEditedStack);
}
}
// Modify display
QFont textfont=currentNodeEdited->font();
textfont.setStrikeOut(true);
this->currentNodeEdited->setFont(textfont);
//
this->DeleteNodeAndSons(this->currentNodeEdited, true);
// Create change
newstack = this->CreateStackElement(DialogPatternXmlEdit::ChangeTypeDelete);
newstack->element= this->currentNodeEdited;
// Activate changes
this->treeChange=true;
ui->pushButton_Apply_Changes->setEnabled(true);
ui->pushButton_Undo_Last_Change->setEnabled(true);
// clear dialog
this->ClearEditData();
return;
}
//---------------------------------------------------------------------------------------------------------------------
bool DialogPatternXmlEdit::DeleteNodeAndSons(VXMLTreeElement * currentNode, bool onlydeactivate)
{
QList<VXMLTreeElement*> stack;
VXMLTreeElement * currentNodeStack;
stack << currentNode;
while (stack.isEmpty() == false)
{
//pop first element
currentNodeStack=stack.takeFirst();
if (onlydeactivate==true)
{
currentNodeStack->SetSetlectable(false);
QFont textfont=currentNodeStack->font();
textfont.setStrikeOut(true);
currentNodeStack->setFont(textfont);
}
// clear all changes made in son node and not on current or it will loop
if (currentNodeStack != currentNode)
{
ChangesStackElement * local = this->changeStackRoot;
while (local != nullptr)
{
if (local->element == currentNodeStack)
{
this->UndoChange(local);
break;
}
local=local->next;
}
}
// add sons to stack
int index=currentNodeStack->rowCount();
while (index > 0)
{
stack << static_cast<VXMLTreeElement *> (currentNodeStack->child(index-1));
index--;
}
//stack.removeFirst();
}
currentNode->SetSetlectable(true);
if (onlydeactivate==false)
{ // Remove node from parent
// Get parent node
QStandardItem * parent= currentNode->parent();
int index=parent->rowCount();
while (index >= 0)
{
if (static_cast<VXMLTreeElement *> (parent->child(index)) == currentNode)
{
break;
}
index--;
}
if (index < 0)
{
Q_ASSERT(index==0);
return false;
}
parent->removeRow(index);
}
return true;
}
//---------------------------------------------------------------------------------------------------------------------
@ -113,14 +234,136 @@ DialogPatternXmlEdit::ChangesStackElement* DialogPatternXmlEdit::CreateStackElem
changeStackLast=changeStackLast->next;
}
changeStackLast->newValue=changeStackLast->newText=nullptr;
changeStackLast->oldValue=changeStackLast->oldText=nullptr;
changeStackLast->next=nullptr;
return changeStackLast;
}
//---------------------------------------------------------------------------------------------------------------------
bool DialogPatternXmlEdit::UndoChange(DialogPatternXmlEdit::ChangesStackElement* current)
{
Q_ASSERT(current != nullptr);
VXMLTreeElement * currentNode = current->element;
if (current->type == DialogPatternXmlEdit::ChangeTypeDelete)
{
if (currentNode->GetelementType()==VXMLTreeElement::TypeAttr)
{
// Attribute previously deleted -> restore
QFont textfont=currentNode->font();
textfont.setStrikeOut(false);
currentNode->setFont(textfont);
this->RemoveChangeStackElement(current);
}
else if (currentNode->GetelementType()==VXMLTreeElement::TypeNode)
{
QList<VXMLTreeElement*> stack;
stack << currentNode;
while (stack.isEmpty() == false)
{
currentNode=stack.takeFirst();
currentNode->SetSetlectable(true);
QFont textfont=currentNode->font();
textfont.setStrikeOut(false);
currentNode->setFont(textfont);
int index=currentNode->rowCount();
while (index > 0)
{
stack << static_cast<VXMLTreeElement *> (currentNode->child(index-1));
index--;
}
}
this->RemoveChangeStackElement(current);
}
}
else if (current->type == DialogPatternXmlEdit::ChangeTypeAdd)
{
if (currentNode->GetelementType()==VXMLTreeElement::TypeAttr)
{
// Get parent node
VXMLTreeElement * parent= static_cast<VXMLTreeElement *> (currentNode->parent());
int index=parent->rowCount();
while (index >= 0)
{
if (static_cast<VXMLTreeElement *> (parent->child(index)) == currentNode)
{
break;
}
index--;
}
if (index < 0)
{
Q_ASSERT(index==0);
return false;
}
parent->removeRow(index);
this->RemoveChangeStackElement(current);
}
else if (currentNode->GetelementType()==VXMLTreeElement::TypeNode)
{
if (this->DeleteNodeAndSons(currentNode, false) == false)
{
// TODO : error message.
return false;
}
this->RemoveChangeStackElement(current);
}
}
else if (current->type == DialogPatternXmlEdit::ChangeTypeModify)
{
if (current->changedText == true)
{
currentNode->SetTreeNodeName(*current->oldText);
}
if (current->changedValue == true)
{
currentNode->SetTreeNodeValue(*current->oldValue);
}
QFont textfont=currentNode->font();
textfont.setBold(false);
currentNode->setFont(textfont);
this->RemoveChangeStackElement(current);
}
// Check if last change was undone
if (this->changeStackLast == nullptr)
{
this->treeChange=false;
ui->pushButton_Apply_Changes->setEnabled(false);
ui->pushButton_Undo_Last_Change->setEnabled(false);
}
return true;
}
//---------------------------------------------------------------------------------------------------------------------
void DialogPatternXmlEdit::ButtonUndoLastChange()
{
ChangesStackElement* current=this->changeStackLast;
if (current == nullptr)
{
QMessageBox::warning(this, tr("No changes"), tr("No changes left"));
this->ui->pushButton_Undo_Last_Change->setEnabled(false);
return;
}
if (this->UndoChange(current) == false)
{
QMessageBox::warning(this, tr("No changes"), tr("Cannot undo change"));
}
this->ClearEditData();
}
//---------------------------------------------------------------------------------------------------------------------
void DialogPatternXmlEdit::ButtonApplyChangesClicked()
{
QString Changes="";
QStringList stringtype;
stringtype << "node" << "attribute" << "root";
QString nodetype;
ChangesStackElement* currentChange;
if (this->changeStackRoot==nullptr)
{
@ -131,20 +374,21 @@ void DialogPatternXmlEdit::ButtonApplyChangesClicked()
currentChange=this->changeStackRoot;
do
{
nodetype=stringtype.at(currentChange->element->GetelementType()-1);
if (currentChange->type == DialogPatternXmlEdit::ChangeTypeAdd)
{
Changes += QString("Added type %1 : ").arg(currentChange->element->getelementType());
Changes += currentChange->element->gettreeNodeName();
Changes += QString("Added type %1 : ").arg(nodetype);
Changes += currentChange->element->GettreeNodeName();
Changes += "/";
Changes += (currentChange->element->gettreeNodeValueSet()) ?
currentChange->element->gettreeNodeValue(): QString(tr("<no value>"));
Changes += (currentChange->element->GettreeNodeValueSet()) ?
currentChange->element->GettreeNodeValue(): QString(tr("<no value>"));
Changes += "\n";
}
else
{
if (currentChange->type == DialogPatternXmlEdit::ChangeTypeModify)
{
Changes += QString("Modified type %1 : ").arg(currentChange->element->getelementType());
Changes += QString("Modified type %1 : ").arg(nodetype);
Changes += (currentChange->changedText) ? *currentChange->newText : QString(tr("Unchanged"));
Changes += "/";
Changes += (currentChange->changedValue) ? *currentChange->newValue: QString(tr("Unchanged"));
@ -154,11 +398,11 @@ void DialogPatternXmlEdit::ButtonApplyChangesClicked()
{
if (currentChange->type == DialogPatternXmlEdit::ChangeTypeDelete)
{
Changes += QString("Deleted type %1 : ").arg(currentChange->element->getelementType());
Changes += currentChange->element->gettreeNodeName();
Changes += QString("Deleted type %1 : ").arg(nodetype);
Changes += currentChange->element->GettreeNodeName();
Changes += "/";
Changes += (currentChange->element->gettreeNodeValueSet()) ?
currentChange->element->gettreeNodeValue(): QString(tr("<no value>"));
Changes += (currentChange->element->GettreeNodeValueSet()) ?
currentChange->element->GettreeNodeValue(): QString(tr("<no value>"));
Changes += "\n";
}
}
@ -176,17 +420,9 @@ void DialogPatternXmlEdit::ButtonCancelClicked()
this->ClearEditData();
if (this->currentNodeEditedStatus==DialogPatternXmlEdit::ChangeTypeDelete)
{
if (this->currentNodeEdited->getelementType() == VXMLTreeElement::TypeAttr)
if (this->UndoChange(this->currentNodeEditedStack) == false)
{
// Attribute previously deleted -> resore
QFont textfont=currentNodeEdited->font();
textfont.setStrikeOut(false);
this->currentNodeEdited->setFont(textfont);
this->RemoveChangeStackElement(this->currentNodeEditedStack);
}
else
{
QMessageBox::information(this, "Not Implemented", "Not Implemented");
QMessageBox::warning(this, "Error", "Cannot undo");
}
}
}
@ -206,6 +442,14 @@ void DialogPatternXmlEdit::RemoveChangeStackElement(ChangesStackElement* elmt)
{
delete elmt->newValue;
}
if (elmt->oldText != nullptr)
{
delete elmt->oldText;
}
if (elmt->oldValue != nullptr)
{
delete elmt->oldValue;
}
this->changeStackRoot = elmt->next;
if (this->changeStackLast == elmt)
{
@ -224,7 +468,7 @@ void DialogPatternXmlEdit::RemoveChangeStackElement(ChangesStackElement* elmt)
}
if (index->next == nullptr)
{
// TODO : debug error here
Q_ASSERT(index->next != nullptr);
return;
}
if (index->next->newText != nullptr)
@ -235,6 +479,14 @@ void DialogPatternXmlEdit::RemoveChangeStackElement(ChangesStackElement* elmt)
{
delete index->next->newValue;
}
if (index->next->oldText != nullptr)
{
delete index->next->oldText;
}
if (index->next->oldValue != nullptr)
{
delete index->next->oldValue;
}
index->next=index->next->next;
if (this->changeStackLast == elmt)
{
@ -253,11 +505,32 @@ void DialogPatternXmlEdit::ButtonDeleteAttributeClicked()
{
return;
}
if (this->currentNodeEdited->getelementType() != VXMLTreeElement::TypeAttr)
if (this->currentNodeEdited->GetelementType() != VXMLTreeElement::TypeAttr)
{
return;
}
if (this->currentNodeEditedStatus != 0)
{
if (this->currentNodeEditedStatus == DialogPatternXmlEdit::ChangeTypeDelete)
{ // Change already done ??? ignore...
return;
}
if (this->currentNodeEditedStatus == DialogPatternXmlEdit::ChangeTypeAdd)
{ // Attribute was previously added, just undo the change
if ( this->UndoChange(this->currentNodeEditedStack) == false )
{ // Error in undo... warn user
QMessageBox::warning(this, tr("No changes"), tr("Cannot delete previously created attribute"));
return;
}
this->ClearEditData();
return;
}
if (this->currentNodeEditedStatus == DialogPatternXmlEdit::ChangeTypeModify)
{ // Node was edited : remove change then continue to delete node
this->UndoChange(this->currentNodeEditedStack);
}
}
newstack = this->CreateStackElement(DialogPatternXmlEdit::ChangeTypeDelete);
newstack->element= this->currentNodeEdited;
@ -267,6 +540,7 @@ void DialogPatternXmlEdit::ButtonDeleteAttributeClicked()
// Activate changes
this->treeChange=true;
ui->pushButton_Apply_Changes->setEnabled(true);
ui->pushButton_Undo_Last_Change->setEnabled(true);
// clear dialog
this->ClearEditData();
}
@ -282,7 +556,7 @@ void DialogPatternXmlEdit::ButtonAddSonClicked()
{
return;
}
if (this->currentNodeEdited->getelementType() != VXMLTreeElement::TypeNode)
if (this->currentNodeEdited->GetelementType() != VXMLTreeElement::TypeNode)
{
return;
}
@ -309,7 +583,7 @@ void DialogPatternXmlEdit::ButtonAddSonClicked()
if (value.isEmpty() == false)
{
tElement->setTreeNodeValue(value);
tElement->SetTreeNodeValue(value);
}
currentNodeEdited->appendRow(tElement);
xmlmodel->appendchain(tElement);
@ -328,6 +602,7 @@ void DialogPatternXmlEdit::ButtonAddSonClicked()
// Activate changes
treeChange=true;
ui->pushButton_Apply_Changes->setEnabled(true);
ui->pushButton_Undo_Last_Change->setEnabled(true);
}
//---------------------------------------------------------------------------------------------------------------------
@ -342,7 +617,7 @@ void DialogPatternXmlEdit::ButtonAddAttributeClicked()
{
return;
}
if (this->currentNodeEdited->getelementType() != VXMLTreeElement::TypeNode)
if (this->currentNodeEdited->GetelementType() != VXMLTreeElement::TypeNode)
{
return;
}
@ -365,7 +640,7 @@ void DialogPatternXmlEdit::ButtonAddAttributeClicked()
// create element tree but do not add attribute in DOM (will be done in apply).
VXMLTreeElement* tElement = new VXMLTreeElement(name, VXMLTreeElement::TypeAttr, empty, true);
tElement->setTreeNodeValue(value);
tElement->SetTreeNodeValue(value);
currentNodeEdited->appendRow(tElement);
xmlmodel->appendchain(tElement);
QFont textfont=currentNodeEdited->font();
@ -380,6 +655,7 @@ void DialogPatternXmlEdit::ButtonAddAttributeClicked()
// Activate changes
treeChange=true;
ui->pushButton_Apply_Changes->setEnabled(true);
ui->pushButton_Undo_Last_Change->setEnabled(true);
}
//---------------------------------------------------------------------------------------------------------------------
@ -388,7 +664,6 @@ void DialogPatternXmlEdit::ButtonSetClicked()
QString name, value;
ChangesStackElement* newstack;
// TODO : check if a change has already been done
if (this->currentNodeEdited == nullptr)
{
return;
@ -397,10 +672,42 @@ void DialogPatternXmlEdit::ButtonSetClicked()
value=ui->lineEdit_Value->text();
bool nameedit, valueedit;
nameedit = (name != currentNodeEdited->gettreeNodeName()) ? true : false;
valueedit= (value != currentNodeEdited->gettreeNodeValue()) ? true : false;
nameedit = (name != currentNodeEdited->GettreeNodeName()) ? true : false;
valueedit= (value != currentNodeEdited->GettreeNodeValue()) ? true : false;
if ( nameedit == true || valueedit == true )
{
if (this->currentNodeEditedStatus != 0)
{ // If node was created or edited previously, rewrite
if (this->currentNodeEditedStatus == DialogPatternXmlEdit::ChangeTypeDelete)
{ // You shouldn't be able to edit a deleted node...
Q_ASSERT(this->currentNodeEditedStatus != DialogPatternXmlEdit::ChangeTypeDelete);
ClearEditData();
return;
}
newstack=this->currentNodeEditedStack;
if (nameedit == true)
{
newstack->changedText=true;
*newstack->newText=name;
currentNodeEdited->SetTreeNodeName(name);
}
if (valueedit == true)
{
if (newstack->changedValue==true)
{
*newstack->newValue = value;
}
else
{
newstack->changedValue=true;
newstack->newValue= new QString(value);
newstack->oldValue= new QString(this->currentNodeEdited->GettreeNodeValue());
}
currentNodeEdited->SetTreeNodeValue(value);
}
}
else
{
newstack = this->CreateStackElement(DialogPatternXmlEdit::ChangeTypeModify);
newstack->element= this->currentNodeEdited;
@ -409,20 +716,23 @@ void DialogPatternXmlEdit::ButtonSetClicked()
{
newstack->changedText=true;
newstack->newText=new QString(name);
currentNodeEdited->setTreeNodeName(name);
newstack->oldText=new QString(this->currentNodeEdited->GettreeNodeName());
currentNodeEdited->SetTreeNodeName(name);
}
if (valueedit == true)
{
newstack->changedValue=true;
newstack->newValue= new QString(value);
currentNodeEdited->setTreeNodeValue(value);
newstack->oldValue= new QString(this->currentNodeEdited->GettreeNodeValue());
currentNodeEdited->SetTreeNodeValue(value);
}
}
QFont textfont=currentNodeEdited->font();
textfont.setBold(true);
currentNodeEdited->setFont(textfont);
treeChange=true;
ui->pushButton_Apply_Changes->setEnabled(true);
ui->pushButton_Undo_Last_Change->setEnabled(true);
ClearEditData();
}
}
@ -457,6 +767,7 @@ void DialogPatternXmlEdit::ClearEditData()
ui->pushButton_Add_son->setEnabled(false);
ui->pushButton_Remove_attribute->setEnabled(false);
ui->pushButton_Cancel_Values->setEnabled(false);
ui->pushButton_Remove_Node->setEnabled(false);
}
//---------------------------------------------------------------------------------------------------------------------
@ -490,7 +801,7 @@ void DialogPatternXmlEdit::BaseSelectionChanged(int value)
if (this->treeChange == true)
{//Changes have been made : warn ?
}
ClearStack();
this->ClearStack();
ui->pushButton_Apply_Changes->setEnabled(false);
index = ui->comboBox_Base_Selection->itemData(value).toInt(); //.convert(QVariant::Int);
@ -503,15 +814,15 @@ void DialogPatternXmlEdit::BaseSelectionChanged(int value)
{
rootNode->removeRow(0);
}
xmlmodel->ClearTree();
this->xmlmodel->ClearTree();
VXMLTreeElement* standard_base = new VXMLTreeElement(
rootBases[index]->gettreeNodeName(),
rootBases[index]->GettreeNodeName(),
VXMLTreeElement::TypeRoot,
rootBases[index]->getDocNode(),
rootBases[index]->GetDocNode(),
false);
rootNode->appendRow(standard_base);
ReadNodes(rootBases[index]->getDocNode(), standard_base, xmlmodel, true);
ReadNodes(rootBases[index]->GetDocNode(), standard_base, xmlmodel, true);
ui->treeView_main->setModel(xmlmodel);
this->ClearEditData();
@ -534,10 +845,15 @@ void DialogPatternXmlEdit::ElementClicked ( const QModelIndex & index )
// Clear all data and disable buttons
this->ClearEditData();
// Check if element is selectable at this time
if (item2->IsSelectable() == false)
{
return;
}
// Check status of element in change stack
this->currentNodeEdited=item2;
this->currentNodeEditedStatus=0;
DialogPatternXmlEdit::ChangesStackElement * local = this->changeStackRoot;
ChangesStackElement * local = this->changeStackRoot;
while (local != nullptr)
{
if (local->element == item2)
@ -554,26 +870,27 @@ void DialogPatternXmlEdit::ElementClicked ( const QModelIndex & index )
local=local->next;
}
// Fill the dialog and Activate the line edit
if (item2->getelementType() != VXMLTreeElement::TypeRoot)
if (item2->GetelementType() != VXMLTreeElement::TypeRoot)
{
ui->lineEdit_Name->setText(currentNodeEdited->gettreeNodeName());
ui->lineEdit_Name->setText(currentNodeEdited->GettreeNodeName());
ui->lineEdit_Name->setEnabled(true);
// Fill value
ui->lineEdit_Value->setText(currentNodeEdited->gettreeNodeValue());
ui->lineEdit_Value->setText(currentNodeEdited->GettreeNodeValue());
ui->lineEdit_Value->setEnabled(true);
}
if (item2->getelementType() == VXMLTreeElement::TypeRoot)
if (item2->GetelementType() == VXMLTreeElement::TypeRoot)
{
ui->label_type_value->setText(tr("Root node"));;
ui->pushButton_Add_son->setEnabled(true);
}
else if (item2->getelementType() == VXMLTreeElement::TypeNode)
else if (item2->GetelementType() == VXMLTreeElement::TypeNode)
{
ui->label_type_value->setText(tr("Node"));
ui->pushButton_Add_attribute->setEnabled(true);
ui->pushButton_Add_son->setEnabled(true);
ui->pushButton_Remove_Node->setEnabled(true);
}
else if (item2->getelementType() == VXMLTreeElement::TypeAttr)
else if (item2->GetelementType() == VXMLTreeElement::TypeAttr)
{
ui->label_type_value->setText(tr("Attribute"));
ui->pushButton_Remove_attribute->setEnabled(true);
@ -583,15 +900,9 @@ void DialogPatternXmlEdit::ElementClicked ( const QModelIndex & index )
//---------------------------------------------------------------------------------------------------------------------
DialogPatternXmlEdit::~DialogPatternXmlEdit()
{
//xmlmodel->clearTree();
this->ClearStack();
this->xmlmodel->ClearTree();
delete ui;
ChangesStackElement * tmp;
while (changeStackRoot != nullptr)
{
tmp=changeStackRoot->next;
delete changeStackRoot;
changeStackRoot=tmp;
}
}
//---------------------------------------------------------------------------------------------------------------------
@ -637,8 +948,8 @@ void DialogPatternXmlEdit::ReadNodes(QDomNode dNode, VXMLTreeElement* root, VXML
do
{
tElement=xmlmodel->getCurrent()->elmt;
tNode=tElement->getDocNode();
if (tElement->getelementType() == VXMLTreeElement::TypeNode)
tNode=tElement->GetDocNode();
if (tElement->GetelementType() == VXMLTreeElement::TypeNode)
{
totalOfChilds = tNode.childNodes().size();
for (int i=0;i<totalOfChilds;i++)
@ -654,14 +965,14 @@ void DialogPatternXmlEdit::ReadNodes(QDomNode dNode, VXMLTreeElement* root, VXML
if (tNode.nodeType() == QDomNode::TextNode)
{
tElement->setTreeNodeValue(tNode.nodeValue());
tElement->SetTreeNodeValue(tNode.nodeValue());
}
for (int i = 0; i < tNode.attributes().size(); i++)
{
tElement2 = new VXMLTreeElement(tNode.attributes().item(i).nodeName(), VXMLTreeElement::TypeAttr,
tNode, false);
tElement2->setTreeNodeValue(tNode.attributes().item(i).nodeValue());
tElement2->SetTreeNodeValue(tNode.attributes().item(i).nodeValue());
tElement->appendRow(tElement2);
xmlmodel->appendchain(tElement2);
}
@ -737,13 +1048,13 @@ const short int VXMLTreeElement::TypeRoot=3;
// ^
VXMLTreeElement::VXMLTreeElement(QString name, int nodetype, QDomNode source, bool editor)
: QStandardItem(name), DocNode(source), addedNode(editor), elementType(nodetype), treeNodeValue("<empty>"),
treeNodeValueSet(false), treeNodeName(name)
treeNodeValueSet(false), treeNodeName(name), selectable(true)
{
if (editor == false)
{
this->DocNode=source;
}
this->setText(this->displayText());
this->setText(this->DisplayText());
switch (this->elementType)
{
case VXMLTreeElement::TypeAttr:
@ -759,22 +1070,22 @@ VXMLTreeElement::~VXMLTreeElement()
{}
//---------------------------------------------------------------------------------------------------------------------
void VXMLTreeElement::setTreeNodeValue(QString value)
void VXMLTreeElement::SetTreeNodeValue(QString value)
{
this->treeNodeValue=value;
this->treeNodeValueSet=true;
this->setText(this->displayText());
this->setText(this->DisplayText());
}
//---------------------------------------------------------------------------------------------------------------------
void VXMLTreeElement::setTreeNodeName(QString value)
void VXMLTreeElement::SetTreeNodeName(QString value)
{
this->treeNodeName=value;
this->setText(this->displayText());
this->setText(this->DisplayText());
}
//---------------------------------------------------------------------------------------------------------------------
QString VXMLTreeElement::displayText()
QString VXMLTreeElement::DisplayText()
{
if (this->elementType == VXMLTreeElement::TypeRoot)
{
@ -784,7 +1095,7 @@ QString VXMLTreeElement::displayText()
}
//---------------------------------------------------------------------------------------------------------------------
QString VXMLTreeElement::gettreeNodeValue()
QString VXMLTreeElement::GettreeNodeValue()
{
// Only return value if it's really set.
if (this->treeNodeValueSet)

View File

@ -40,6 +40,7 @@
*/
#define BACKGROUND_COLOR_ATTRIBUTE QBrush(Qt::GlobalColor::cyan)
#define BACKGROUND_COLOR_INACTIVE_NODE QBrush(Qt::GlobalColor::gray)
class VXMLTreeElement : public QStandardItem
{
@ -62,26 +63,28 @@ public:
* @brief setNodeValue : set value of node (content or attribute)
* @param value : the value
*/
void setTreeNodeValue(QString value);
void SetTreeNodeValue(QString value);
/**
* @brief displayText : text to display
* @return text to display
*/
QString displayText();
QString DisplayText();
/**
* @brief getDocNode
* @return current document node
*/
QDomNode getDocNode();
QString gettreeNodeName();
QString gettreeNodeValue();
bool gettreeNodeValueSet();
void setTreeNodeName(QString value);
QDomNode GetDocNode();
QString GettreeNodeName();
QString GettreeNodeValue();
bool GettreeNodeValueSet();
void SetTreeNodeName(QString value);
/**
* @brief getelementType
* @return elementType value
*/
short int getelementType();
short int GetelementType();
bool IsSelectable();
void SetSetlectable(bool value);
private:
/**
@ -109,25 +112,39 @@ private:
* @brief nodeValue : Attribute or node value
*/
QString treeNodeName;
/**
* @brief selectable : can item be selected to be changed (ex : false if father deleted).
*/
bool selectable;
Q_DISABLE_COPY(VXMLTreeElement)
};
inline short int VXMLTreeElement::getelementType()
inline bool VXMLTreeElement::IsSelectable()
{
return this->selectable;
}
inline void VXMLTreeElement::SetSetlectable(bool value)
{
this->selectable=value;
}
inline short int VXMLTreeElement::GetelementType()
{
return this->elementType;
}
inline QDomNode VXMLTreeElement::getDocNode()
inline QDomNode VXMLTreeElement::GetDocNode()
{
return this->DocNode;
}
inline QString VXMLTreeElement::gettreeNodeName()
inline QString VXMLTreeElement::GettreeNodeName()
{
return this->treeNodeName;
}
inline bool VXMLTreeElement::gettreeNodeValueSet()
inline bool VXMLTreeElement::GettreeNodeValueSet()
{
return this->treeNodeValueSet;
}
@ -224,7 +241,8 @@ public:
void ButtonAddSonClicked();
void ButtonAddAttributeClicked();
void ButtonApplyChangesClicked();
void ButtonUndoLastChange();
void ButtonDeleteNode();
// Stack of changes definition
typedef struct ChangesStackElement
@ -232,8 +250,10 @@ public:
short int type;
VXMLTreeElement *element;
QString *newText;
QString *oldText;
bool changedText;
QString *newValue;
QString *oldValue;
bool changedValue;
ChangesStackElement* next;
} ChangesStackElement;
@ -246,6 +266,19 @@ public:
VXMLTreeElement* currentNodeEdited;
short int currentNodeEditedStatus;
ChangesStackElement* currentNodeEditedStack;
/**
* @brief UndoChange : undo change in change stack element
* @param current : change to undo
* @return true if undo has been done, false on error
*/
bool UndoChange(ChangesStackElement* current);
/**
* @brief DeleteNodeAndSons : delete node and all it's attribute and sons below
* @param currentNode : node to delete
* @param onlydeactivate : if true, dont delete just deactivate sons and attributes
* @return false if changes couldn't be done
*/
bool DeleteNodeAndSons(VXMLTreeElement *currentNode, bool onlydeactivate);
private slots:
void BaseSelectionChanged(int value);

View File

@ -200,7 +200,7 @@
</widget>
</item>
<item row="0" column="1">
<widget class="QPushButton" name="pushButton_Remove_attribute_2">
<widget class="QPushButton" name="pushButton_Remove_Node">
<property name="enabled">
<bool>false</bool>
</property>
@ -272,12 +272,12 @@
</widget>
</item>
<item row="3" column="1">
<widget class="QPushButton" name="pushButton_Cancel_Changes">
<widget class="QPushButton" name="pushButton_Undo_Last_Change">
<property name="enabled">
<bool>false</bool>
</property>
<property name="text">
<string>Cancel changes</string>
<string>Undo last</string>
</property>
</widget>
</item>