mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-18 05:00:33 +01:00
Rapatriement de la branche 0.2 dans le trunk
git-svn-id: svn+ssh://svn.tuxfamily.org/svnroot/qet/qet/trunk@558 bfdf4180-ca20-0410-9c96-a3a8aa849046
This commit is contained in:
201
sources/integrationmoveelementshandler.cpp
Normal file
201
sources/integrationmoveelementshandler.cpp
Normal file
@@ -0,0 +1,201 @@
|
||||
#include "integrationmoveelementshandler.h"
|
||||
#include <QtGui>
|
||||
#include "elementscategory.h"
|
||||
#include "elementdefinition.h"
|
||||
#include "qfilenameedit.h"
|
||||
|
||||
/**
|
||||
Constructeur
|
||||
@param parent QWidget parent a utiliser pour l'affichage des dialogues lors
|
||||
des interactions avec l'utilisateur
|
||||
*/
|
||||
IntegrationMoveElementsHandler::IntegrationMoveElementsHandler(QWidget *parent) :
|
||||
BasicMoveElementsHandler(parent),
|
||||
parent_widget_(parent),
|
||||
integ_dialog_(0)
|
||||
{
|
||||
// actions par defaut : abort
|
||||
setActionIfItemAlreadyExists(QET::Abort);
|
||||
setActionIfItemIsNotReadable(QET::Abort);
|
||||
setActionIfItemIsNotWritable(QET::Abort);
|
||||
setActionIfItemTriggersAnError(QET::Abort);
|
||||
}
|
||||
|
||||
/**
|
||||
Destructeur
|
||||
*/
|
||||
IntegrationMoveElementsHandler::~IntegrationMoveElementsHandler() {
|
||||
}
|
||||
|
||||
/**
|
||||
@param src Element source
|
||||
@param dst Element cible / destination
|
||||
@return l'action a effectuer si l'element cible existe deja
|
||||
*/
|
||||
QET::Action IntegrationMoveElementsHandler::elementAlreadyExists(ElementDefinition *src, ElementDefinition *dst) {
|
||||
// premiere etape : on verifie si src et dst ne sont pas identiques
|
||||
if (src -> equals(*dst)) {
|
||||
// les deux elements sont identiques - il est inutile d'ecraser l'ancien
|
||||
return(QET::Ignore);
|
||||
}
|
||||
|
||||
// les deux elements sont differents - on demande a l'utilisateur ce qu'il
|
||||
// prefere : ecrasement ou cohabitation
|
||||
return(askUser(src, dst));
|
||||
}
|
||||
|
||||
/**
|
||||
@return le nom a utiliser pour le renommage si une methode de cet objet
|
||||
a precedemment renvoye QET::Rename.
|
||||
*/
|
||||
QString IntegrationMoveElementsHandler::nameForRenamingOperation() {
|
||||
return(rename_);
|
||||
}
|
||||
|
||||
/**
|
||||
@return la date courante au format yyyyMMddhhmmss
|
||||
*/
|
||||
QString IntegrationMoveElementsHandler::dateString() const {
|
||||
return(QDateTime::currentDateTime().toString("yyyyMMddhhmmss"));
|
||||
}
|
||||
|
||||
/**
|
||||
@param element Une definition d'element
|
||||
@return un nom pour dupliquer l'element passe en parametre. Ce nom est base
|
||||
sur la date courante.
|
||||
*/
|
||||
QString IntegrationMoveElementsHandler::newNameForElement(const ElementDefinition *element) {
|
||||
QString orig_name = element -> pathName();
|
||||
if (orig_name.endsWith(".elmt")) orig_name.chop(5);
|
||||
return(orig_name + "-" + dateString() + ".elmt");
|
||||
}
|
||||
|
||||
/**
|
||||
Demande a l'utilisateur s'il souhaite ecraser l'elemen deja existant,
|
||||
renommer le nouveau ou bien annuler
|
||||
@param src Element source
|
||||
@param dst Element cible
|
||||
@return la reponse de l'utilisateur
|
||||
*/
|
||||
QET::Action IntegrationMoveElementsHandler::askUser(ElementDefinition */*src*/, ElementDefinition *dst) {
|
||||
initDialog();
|
||||
int result = integ_dialog_ -> exec();
|
||||
if (result == QDialog::Accepted) {
|
||||
if (use_existing_elmt_ -> isChecked()) {
|
||||
return(QET::Ignore);
|
||||
} else if (erase_element_ -> isChecked()) {
|
||||
return(QET::Erase);
|
||||
} else {
|
||||
rename_ = newNameForElement(dst);
|
||||
return(QET::Rename);
|
||||
}
|
||||
} else {
|
||||
return(QET::Abort);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
Initialise le dialogue
|
||||
*/
|
||||
void IntegrationMoveElementsHandler::initDialog() {
|
||||
if (integ_dialog_) return;
|
||||
integ_dialog_ = new QDialog(parent_widget_);
|
||||
integ_dialog_ -> setWindowTitle(tr("Int\351gration d'un \351l\351ment"));
|
||||
|
||||
dialog_label_ = new QLabel(
|
||||
QString(
|
||||
tr(
|
||||
"L'\351l\351ment a d\351j\340 \351t\351 "
|
||||
"int\351gr\351 dans le projet. Toutefois, la version que vous "
|
||||
"tentez de poser semble diff\351rente. Que souhaitez-vous "
|
||||
"faire ?",
|
||||
"dialog content - %1 is an element's path name"
|
||||
)
|
||||
)
|
||||
);
|
||||
|
||||
use_existing_elmt_ = new QRadioButton(
|
||||
QString(
|
||||
tr(
|
||||
"Utiliser l'\351l\351ment d\351j\340 int\351gr\351",
|
||||
"dialog content"
|
||||
)
|
||||
)
|
||||
);
|
||||
|
||||
integrate_new_element_ = new QRadioButton(
|
||||
QString(
|
||||
tr(
|
||||
"Int\351grer l'\351l\351ment d\351pos\351",
|
||||
"dialog content"
|
||||
)
|
||||
)
|
||||
);
|
||||
radioButtonleftMargin(integrate_new_element_);
|
||||
|
||||
erase_element_ = new QRadioButton(
|
||||
QString(
|
||||
tr(
|
||||
"\311craser l'\351l\351ment d\351j\340 int\351gr\351",
|
||||
"dialog content"
|
||||
)
|
||||
)
|
||||
);
|
||||
radioButtonleftMargin(erase_element_);
|
||||
|
||||
integrate_both_ = new QRadioButton(
|
||||
QString(
|
||||
tr(
|
||||
"Faire cohabiter les deux \351l\351ments",
|
||||
"dialog content"
|
||||
)
|
||||
)
|
||||
);
|
||||
|
||||
button_group1_ = new QButtonGroup(this);
|
||||
button_group1_ -> addButton(use_existing_elmt_);
|
||||
button_group1_ -> addButton(integrate_new_element_);
|
||||
button_group2_ = new QButtonGroup(this);
|
||||
button_group2_ -> addButton(erase_element_);
|
||||
button_group2_ -> addButton(integrate_both_);
|
||||
|
||||
integrate_new_element_ -> setChecked(true);
|
||||
integrate_both_ -> setChecked(true);
|
||||
|
||||
buttons_ = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel);
|
||||
|
||||
dialog_glayout = new QGridLayout();
|
||||
dialog_glayout -> setColumnMinimumWidth(0, 20);
|
||||
dialog_glayout -> addWidget(erase_element_, 0, 1);
|
||||
dialog_glayout -> addWidget(integrate_both_, 1, 1);
|
||||
|
||||
dialog_vlayout_ = new QVBoxLayout(integ_dialog_);
|
||||
dialog_vlayout_ -> addWidget(dialog_label_);
|
||||
dialog_vlayout_ -> addWidget(use_existing_elmt_);
|
||||
dialog_vlayout_ -> addWidget(integrate_new_element_);
|
||||
dialog_vlayout_ -> addLayout(dialog_glayout);
|
||||
dialog_vlayout_ -> addWidget(buttons_);
|
||||
|
||||
connect(use_existing_elmt_, SIGNAL(toggled(bool)), this, SLOT(correctRadioButtons()));
|
||||
connect(integrate_new_element_, SIGNAL(toggled(bool)), this, SLOT(correctRadioButtons()));
|
||||
connect(buttons_, SIGNAL(accepted()), integ_dialog_, SLOT(accept()));
|
||||
connect(buttons_, SIGNAL(rejected()), integ_dialog_, SLOT(reject()));
|
||||
}
|
||||
|
||||
/**
|
||||
S'asure que le dialogue reste coherent
|
||||
*/
|
||||
void IntegrationMoveElementsHandler::correctRadioButtons() {
|
||||
erase_element_ -> setEnabled(integrate_new_element_ -> isChecked());
|
||||
integrate_both_ -> setEnabled(integrate_new_element_ -> isChecked());
|
||||
}
|
||||
|
||||
/**
|
||||
@param button bouton radio
|
||||
Augmente la marge gauche d'un bouton radio
|
||||
*/
|
||||
void IntegrationMoveElementsHandler::radioButtonleftMargin(QRadioButton *button) {
|
||||
int a, b, c, d;
|
||||
button -> getContentsMargins(&a, &b, &c, &d);
|
||||
button -> setContentsMargins(a + 15, b, c, d);
|
||||
}
|
||||
Reference in New Issue
Block a user