master propertie widget:

can link/unlink slave to master
can show element by double clic item on the list
reset modification 


git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@2878 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
blacksun 2014-02-26 23:57:22 +00:00
parent 322ba055c0
commit bf707cca2e
7 changed files with 180 additions and 13 deletions

View File

@ -1152,11 +1152,11 @@ void ImageResizerCommand::redo() {
LinkElementsCommand::LinkElementsCommand(Element *elmt1, Element *elmt2, QUndoCommand *parent) :
QUndoCommand(parent),
diagram_(elmt1->diagram()),
elmt_1(elmt1),
elmt_2(elmt2),
element_(elmt1),
previous_report(0),
first_redo(true)
{
elmt_list << elmt2;
if (elmt1->linkType() & Element::AllReport &&
elmt2->linkType() & Element::AllReport) {
setText(QObject::tr("Lier deux reports de folio",
@ -1164,6 +1164,21 @@ LinkElementsCommand::LinkElementsCommand(Element *elmt1, Element *elmt2, QUndoCo
if(!elmt1->isFree())
previous_report = elmt1->linkedElements().first();
}
else if (element_->linkType() & Element::Master)
setText(QObject::tr("Editer les r\351f\351rence crois\351", "edite the cross reference"));
else setText(QObject::tr("Lier deux éléments"));
}
LinkElementsCommand::LinkElementsCommand(Element *elmt1, QList<Element *> &elmtList, QUndoCommand *parent) :
QUndoCommand(parent),
diagram_(elmt1->diagram()),
element_(elmt1),
elmt_list(elmtList),
previous_report(0),
first_redo(true)
{
if (element_->linkType() & Element::Master)
setText(QObject::tr("Editer les r\351f\351rence crois\351"));
else setText(QObject::tr("Lier deux éléments"));
}
@ -1179,9 +1194,13 @@ LinkElementsCommand::~LinkElementsCommand(){}
*/
void LinkElementsCommand::undo() {
diagram_->showMe();
elmt_1->unlinkElement(elmt_2);
foreach (Element *elmt, elmt_list)
element_->unlinkElement(elmt);
if (previous_report)
elmt_1->linkToElement(previous_report);
element_->linkToElement(previous_report);
QUndoCommand::undo();
}
/**
@ -1190,14 +1209,18 @@ void LinkElementsCommand::undo() {
*/
void LinkElementsCommand::redo() {
diagram_->showMe();
elmt_1->linkToElement(elmt_2);
//Check if text of this potential is identical.
if (first_redo) {
if(elmt_1->conductors().count() && elmt_2->conductors().count()) {
ConductorAutoNumerotation::checkPotential(elmt_1->conductors().first());
foreach (Element *elmt, elmt_list)
element_->linkToElement(elmt);
//If element are report, check if text of this potential is identical.
if ((element_->linkType() &Element::AllReport) && first_redo) {
if(element_->conductors().count() && elmt_list.first()->conductors().count()) {
ConductorAutoNumerotation::checkPotential(element_->conductors().first());
}
first_redo = false;
}
QUndoCommand::redo();
}
/**
@ -1217,6 +1240,21 @@ unlinkElementsCommand::unlinkElementsCommand(Element *elmt1, Element *elmt2, QUn
setText(QObject::tr("D\351lier %n \351l\351ment(s)", "", elmt_list.size()));
}
/**
* @brief unlinkElementsCommand::unlinkElementsCommand
* @param elmt1 Element to set the link
* @param elmtList list of all element to be linked to elmt1
* @param parent undo command
*/
unlinkElementsCommand::unlinkElementsCommand(Element *elmt1, QList<Element *> &elmtList, QUndoCommand *parent):
QUndoCommand(parent),
diagram_(elmt1->diagram()),
element_(elmt1),
elmt_list(elmtList)
{
setText(QObject::tr("D\351lier %n \351l\351ment(s)", "", elmt_list.size()));
}
/**
* @brief unlinkElementsCommand::~unlinkElementsCommand
* destructor
@ -1230,6 +1268,7 @@ unlinkElementsCommand::~unlinkElementsCommand(){}
void unlinkElementsCommand::undo() {
foreach (Element *elmt, elmt_list)
element_->linkToElement(elmt);
QUndoCommand::undo();
}
/**
@ -1239,4 +1278,5 @@ void unlinkElementsCommand::undo() {
void unlinkElementsCommand::redo() {
foreach (Element *elmt, elmt_list)
element_->unlinkElement(elmt);
QUndoCommand::redo();
}

View File

@ -591,6 +591,7 @@ class LinkElementsCommand : public QUndoCommand {
public:
// constructor destructor
LinkElementsCommand (Element *elmt1, Element *elmt2, QUndoCommand *parent = 0);
LinkElementsCommand (Element *elmt1, QList <Element *> &elmtList, QUndoCommand *parent = 0);
virtual ~LinkElementsCommand();
//methods
virtual void undo();
@ -599,7 +600,8 @@ class LinkElementsCommand : public QUndoCommand {
private:
//attributes
Diagram *diagram_;
Element *elmt_1, *elmt_2, *previous_report;
Element *element_, *previous_report;
QList <Element *> elmt_list;
bool first_redo;
};
@ -607,6 +609,7 @@ class unlinkElementsCommand : public QUndoCommand {
public:
//constructor destructor
unlinkElementsCommand (Element *elmt1, Element *elmt2 = 0, QUndoCommand *parent = 0);
unlinkElementsCommand (Element *elmt1, QList <Element *> &elmtList, QUndoCommand *parent = 0);
virtual ~unlinkElementsCommand();
//methods
virtual void undo();

View File

@ -158,10 +158,12 @@ void elementpropertieswidget::standardButtonClicked(QAbstractButton *button) {
switch (answer) {
case QDialogButtonBox::ResetRole:
if (mpw_) mpw_->reset();
break;
case QDialogButtonBox::ApplyRole:
if (frp_) frp_->Apply(); //folio report widget
else if (eiw_) eiw_->apply(); //element information widget
if (frp_) frp_->Apply(); //folio report widget
if (eiw_) eiw_->apply(); //element information widget
if (mpw_) mpw_->apply(); //master property widget
this->accept();
case QDialogButtonBox::RejectRole:
this->reject();

View File

@ -140,8 +140,10 @@ void FolioReportProperties::unlinkClicked() {
* @param elmt: element to be displayed
*/
void FolioReportProperties::showElement(Element *elmt) {
QList <Element *> elmt_list = element_list;
elmt_list << element_->linkedElements() << element_;
foreach (Element *elmt, elmt_list) elmt->setSelected(false);
elmt->diagram()->showMe();
foreach (QGraphicsItem *qgi, elmt->diagram()->selectedItems()) qgi->setSelected(false);
elmt->setSelected(true);
}

View File

@ -25,6 +25,11 @@ namespace Ui {
class FolioReportProperties;
}
/**
* @brief The FolioReportProperties class
* This class is a widget for make link between two reports element.
* This class embendded the undo/redo command when apply new connection.
*/
class FolioReportProperties : public QWidget
{
Q_OBJECT

View File

@ -20,7 +20,14 @@
#include <QListWidgetItem>
#include <diagramposition.h>
#include <elementprovider.h>
#include <diagramcommands.h>
/**
* @brief MasterPropertiesWidget::MasterPropertiesWidget
* Default constructor
* @param elmt
* @param parent
*/
MasterPropertiesWidget::MasterPropertiesWidget(Element *elmt, QWidget *parent) :
QWidget(parent),
ui(new Ui::MasterPropertiesWidget),
@ -28,14 +35,80 @@ MasterPropertiesWidget::MasterPropertiesWidget(Element *elmt, QWidget *parent) :
{
ui->setupUi(this);
buildInterface();
connect(ui->free_list, SIGNAL(itemDoubleClicked(QListWidgetItem*)), this, SLOT(showElementFromLWI(QListWidgetItem*)));
connect(ui->linked_list, SIGNAL(itemDoubleClicked(QListWidgetItem*)), this, SLOT(showElementFromLWI(QListWidgetItem*)));
}
/**
* @brief MasterPropertiesWidget::~MasterPropertiesWidget
* Destructor
*/
MasterPropertiesWidget::~MasterPropertiesWidget()
{
foreach(Element *elmt, lwi_hash.values()) elmt->setHighlighted(false);
delete ui;
}
/**
* @brief MasterPropertiesWidget::apply
* Do what we need when apply new conf
*/
void MasterPropertiesWidget::apply() {
QList <Element *> to_link;
QList <Element *> linked_ = element_->linkedElements();
for (int i=0; i<ui->linked_list->count(); i++) {
to_link << lwi_hash[ui->linked_list->item(i)];
}
//If same element are find in to_link and linked, that means
// element are already linked, so we remove element on the two list
//if linked_ contains element at the end of the operation,
//that means this element must be unlinked from @element_
foreach (Element *elmt, to_link) {
if(linked_.contains(elmt)) {
to_link.removeAll(elmt);
linked_.removeAll(elmt);
}
}
// if two list, contain element, we link and unlink @element_ with corresponding
//undo command, and add first command for parent of the second, user see only one
//undo command
if (linked_.count() && to_link.count()) {
LinkElementsCommand *lec = new LinkElementsCommand(element_, to_link);
new unlinkElementsCommand(element_, linked_, lec);
element_->diagram()->undoStack().push(lec);
}
//Else do the single undo command corresponding to the link.
else if (to_link.count()) {
LinkElementsCommand *lec = new LinkElementsCommand(element_, to_link);
element_->diagram()->undoStack().push(lec);
}
else if (linked_.count()) {
unlinkElementsCommand *uec = new unlinkElementsCommand(element_, linked_);
element_->diagram()->undoStack().push(uec);
}
}
/**
* @brief MasterPropertiesWidget::reset
* Reset curent widget, clear eveything and rebuild widget.
*/
void MasterPropertiesWidget::reset() {
foreach (QListWidgetItem *lwi, lwi_hash.keys()) {
delete lwi;
}
lwi_hash.clear();
buildInterface();
}
/**
* @brief MasterPropertiesWidget::buildInterface
* Build the interface of the widget
*/
void MasterPropertiesWidget::buildInterface() {
//build the free list
ElementProvider elmt_prov(element_->diagram()->project());
foreach(Element *elmt, elmt_prov.freeElement(Element::Slave)) {
@ -47,8 +120,23 @@ void MasterPropertiesWidget::buildInterface() {
.arg(title)
.arg(elmt->diagram() -> convertPosition(elmt -> scenePos()).toString());
QListWidgetItem *lwi_ = new QListWidgetItem(elmt->pixmap(), widget_text);
lwi_hash.insert(lwi_, elmt);
ui->free_list->addItem(lwi_);
}
//build the linked list
foreach(Element *elmt, element_->linkedElements()) {
//label for list widget
QString widget_text;
QString title = elmt->diagram()->title();
if (title.isEmpty()) title = tr("Sans titre");
widget_text += QString(tr("Folio\240 %1 (%2), position %3.")).arg(elmt->diagram()->folioIndex() + 1)
.arg(title)
.arg(elmt->diagram() -> convertPosition(elmt -> scenePos()).toString());
QListWidgetItem *lwi_ = new QListWidgetItem(elmt->pixmap(), widget_text);
lwi_hash.insert(lwi_, elmt);
ui->linked_list->addItem(lwi_);
}
}
/**
@ -62,9 +150,25 @@ void MasterPropertiesWidget::on_link_button_clicked() {
ui->free_list->currentRow()));
}
/**
* @brief MasterPropertiesWidget::on_unlink_button_clicked
* move curent item in linked_list to free_list
*/
void MasterPropertiesWidget::on_unlink_button_clicked() {
//take the curent item from linked_list and push it to free_list
ui->free_list->addItem(
ui->linked_list->takeItem(
ui->linked_list->currentRow()));
}
/**
* @brief MasterPropertiesWidget::showElementFromLWI
* Show the element corresponding to the given QListWidgetItem
* @param lwi
*/
void MasterPropertiesWidget::showElementFromLWI(QListWidgetItem *lwi) {
foreach(Element *elmt, lwi_hash.values()) elmt->setHighlighted(false);
Element *elmt = lwi_hash[lwi];
elmt->diagram()->showMe();
elmt->setHighlighted(true);
}

View File

@ -25,6 +25,12 @@ namespace Ui {
class MasterPropertiesWidget;
}
/**
* @brief The MasterPropertiesWidget class
* This class is a widget for make link between a master element with several slave element.
* This class embenddedthe undo/redo command when apply new connection.
*/
class MasterPropertiesWidget : public QWidget
{
Q_OBJECT
@ -33,16 +39,21 @@ class MasterPropertiesWidget : public QWidget
explicit MasterPropertiesWidget(Element *elmt, QWidget *parent = 0);
~MasterPropertiesWidget();
void apply();
void reset();
private:
void buildInterface();
private slots:
void on_link_button_clicked();
void on_unlink_button_clicked();
void showElementFromLWI(QListWidgetItem *lwi);
private:
Ui::MasterPropertiesWidget *ui;
Element *element_;
QHash <QListWidgetItem *, Element *> lwi_hash;
};
#endif // MASTERPROPERTIESWIDGET_H