diff --git a/sources/configpages.h b/sources/configpages.h index f429ef29e..dc60a64c8 100644 --- a/sources/configpages.h +++ b/sources/configpages.h @@ -19,8 +19,8 @@ #define CONFIG_PAGES_H #include #include "configpage.h" -#include "projectpropertiesdialog.h" //davi -#include "titleblockpropertieswidget.h" //davi +#include "projectpropertiesdialog.h" +#include "titleblockpropertieswidget.h" class BorderPropertiesWidget; class ConductorPropertiesWidget; class TitleBlockPropertiesWidget; diff --git a/sources/numerotationcontext.cpp b/sources/numerotationcontext.cpp index b275b539a..710b41258 100644 --- a/sources/numerotationcontext.cpp +++ b/sources/numerotationcontext.cpp @@ -99,7 +99,7 @@ QStringList NumerotationContext::itemAt(const int i) const { * @return all type use to numerotation */ QString NumerotationContext::validRegExpNum () const { - return ("unit|ten|hundred|string|folio"); + return ("unit|ten|hundred|string|idfolio|folio"); } /** diff --git a/sources/numerotationcontextcommands.cpp b/sources/numerotationcontextcommands.cpp index 306137da0..cb3c414d9 100644 --- a/sources/numerotationcontextcommands.cpp +++ b/sources/numerotationcontextcommands.cpp @@ -104,7 +104,11 @@ void NumerotationContextCommands::setNumStrategy(const QString &str) { strategy_ = new StringNum (diagram_); return; } - else if (str == "folio") { + else if (str == "idfolio") { + strategy_ = new IdFolioNum (diagram_); + return; + } + else if (str=="folio"){ strategy_ = new FolioNum (diagram_); return; } @@ -291,6 +295,37 @@ NumerotationContext StringNum::previous(const NumerotationContext &nc, const int return (nextString(nc, i)); } +/** + * Constructor + */ +IdFolioNum::IdFolioNum (Diagram *d): + NumStrategy (d) +{} + +/** + * @brief IdFolioNum::toRepresentedString + * @return the represented string of num + */ +QString IdFolioNum::toRepresentedString(const QString str) const { + Q_UNUSED(str); + return (QString::number(diagram_ -> folioIndex() + 1)); +} + +/** + * @brief IdFolioNum::next + * @return the next NumerotationContext nc at position i + */ +NumerotationContext IdFolioNum::next (const NumerotationContext &nc, const int i) const { + return (nextString(nc, i)); +} + +/** + * @brief IdFolioNum::previous + * @return the previous NumerotationContext nc at posiiton i + */ +NumerotationContext IdFolioNum::previous(const NumerotationContext &nc, const int i) const { + return (nextString(nc, i)); +} /** * Constructor @@ -301,11 +336,11 @@ FolioNum::FolioNum (Diagram *d): /** * @brief FolioNum::toRepresentedString - * @return the represented string of num + * @return the represented string of folio */ QString FolioNum::toRepresentedString(const QString str) const { Q_UNUSED(str); - return (QString::number(diagram_ -> folioIndex() + 1)); + return (diagram_->border_and_titleblock.folio()); } /** diff --git a/sources/numerotationcontextcommands.h b/sources/numerotationcontextcommands.h index 4b1b333e6..18a6a5e71 100644 --- a/sources/numerotationcontextcommands.h +++ b/sources/numerotationcontextcommands.h @@ -96,6 +96,15 @@ class StringNum: public NumStrategy NumerotationContext previous (const NumerotationContext &, const int) const; }; +class IdFolioNum: public NumStrategy +{ + public: + IdFolioNum (Diagram *); + QString toRepresentedString(const QString) const; + NumerotationContext next (const NumerotationContext &, const int) const; + NumerotationContext previous (const NumerotationContext &, const int) const; +}; + class FolioNum: public NumStrategy { public: @@ -104,5 +113,4 @@ class FolioNum: public NumStrategy NumerotationContext next (const NumerotationContext &, const int) const; NumerotationContext previous (const NumerotationContext &, const int) const; }; - #endif // NUMEROTATIONCONTEXTCOMMANDS_H diff --git a/sources/projectconfigpages.cpp b/sources/projectconfigpages.cpp index 0110af99d..3544143a4 100644 --- a/sources/projectconfigpages.cpp +++ b/sources/projectconfigpages.cpp @@ -159,10 +159,10 @@ QString ProjectMainConfigPage::projectTitle() const { void ProjectMainConfigPage::initWidgets() { title_label_ = new QLabel(tr("Titre du projet :", "label when configuring")); title_value_ = new QLineEdit(); - title_information_ = new QLabel(tr("Ce titre sera disponible pour tous les folios de ce projet en tant que %projecttitle.", "informative label")); + title_information_ = new QLabel(tr("Ce titre sera disponible pour tous les folios de ce projet en tant que %projecttitle.", "informative label")); project_variables_label_ = new QLabel( tr( - "Vous pouvez définir ci-dessous des propriétés personnalisées qui seront disponibles pour tous les folios de ce projet (typiquement pour les cartouches).", + "Vous pouvez définir ci-dessous des propriétés personnalisées qui seront disponibles pour tous les folios de ce projet (typiquement pour les cartouches).", "informative label" ) ); @@ -252,43 +252,42 @@ void ProjectAutoNumConfigPage::applyProjectConf() {} */ void ProjectAutoNumConfigPage::initWidgets() { - tab_widget = new QTabWidget(this); - tab_widget->setMinimumWidth(440); + tab_widget = new QTabWidget(this); - //Conductor Tab - conductor_tab_widget = new QWidget(this); + //Conductor Tab + conductor_tab_widget = new QWidget(this); - m_label = new QLabel(tr("Numérotations disponibles :", "availables numerotations"), conductor_tab_widget); + m_label = new QLabel(tr("Numérotations disponibles :", "availables numerotations"), conductor_tab_widget); - m_context_cb = new QComboBox(conductor_tab_widget); + m_context_cb = new QComboBox(conductor_tab_widget); m_context_cb->setEditable(true); m_context_cb->lineEdit()->setClearButtonEnabled(true); m_context_cb->addItem(tr("Nom de la nouvelle numérotation")); - m_remove_pb = new QPushButton(QET::Icons::EditDelete, QString(), conductor_tab_widget); + m_remove_pb = new QPushButton(QET::Icons::EditDelete, QString(), conductor_tab_widget); m_remove_pb -> setToolTip(tr("Supprimer la numérotation")); - m_saw = new SelectAutonumW(conductor_tab_widget); + m_saw = new SelectAutonumW(conductor_tab_widget); - //Folio Tab - folio_tab_widget = new QWidget(this); + //Folio Tab + folio_tab_widget = new QWidget(this); + folio_tab_widget->setObjectName("FolioTab"); - m_label_2 = new QLabel(tr("Numérotations disponibles :", "availables numerotations"), folio_tab_widget); + m_label_2 = new QLabel(tr("Numérotations disponibles :", "availables numerotations"), folio_tab_widget); - m_context_cb_2 = new QComboBox(folio_tab_widget); - m_context_cb_2->setEditable(true); - m_context_cb_2->lineEdit()->setClearButtonEnabled(true); - m_context_cb_2->addItem(tr("Nom de la nouvelle numérotation")); + m_context_cb_2 = new QComboBox(folio_tab_widget); + m_context_cb_2->setEditable(true); + m_context_cb_2->lineEdit()->setClearButtonEnabled(true); + m_context_cb_2->addItem(tr("Nom de la nouvelle numérotation")); - m_remove_pb_2 = new QPushButton(QET::Icons::EditDelete, QString(), folio_tab_widget); - m_remove_pb_2 -> setToolTip(tr("Supprimer la numérotation")); + m_remove_pb_2 = new QPushButton(QET::Icons::EditDelete, QString(), folio_tab_widget); + m_remove_pb_2 -> setToolTip(tr("Supprimer la numérotation")); - m_saw_2 = new SelectAutonumW(folio_tab_widget); + m_saw_2 = new SelectAutonumW(folio_tab_widget); -/* //AutoNumbering Tab - Needs Further Testing - autoNumbering_tab_widget = new QWidget(this); - m_faw = new FolioAutonumberingW(project(),autoNumbering_tab_widget); -*/ + //AutoNumbering Tab + autoNumbering_tab_widget = new QWidget(this); + m_faw = new FolioAutonumberingW(project(),autoNumbering_tab_widget); } /** @@ -296,40 +295,43 @@ void ProjectAutoNumConfigPage::initWidgets() { * Init the layout of this page */ void ProjectAutoNumConfigPage::initLayout() { - //Conductor tab - tab_widget->addTab(conductor_tab_widget, tr("Conductor")); - QHBoxLayout *context_layout = new QHBoxLayout(); + //Conductor tab + tab_widget->addTab(conductor_tab_widget, tr("Conductor")); + + QHBoxLayout *context_layout = new QHBoxLayout(); context_layout -> addWidget (m_label); context_layout -> addWidget (m_context_cb); context_layout -> addWidget (m_remove_pb); - QVBoxLayout *main_layout = new QVBoxLayout(); - QVBoxLayout *aux_layout = new QVBoxLayout(); - aux_layout->addLayout(context_layout); - aux_layout->addWidget(m_saw); + QVBoxLayout *main_layout = new QVBoxLayout(); + QVBoxLayout *aux_layout = new QVBoxLayout(); + aux_layout->addLayout(context_layout); + aux_layout->addWidget(m_saw); - main_layout->addLayout(aux_layout); - conductor_tab_widget -> setLayout (main_layout); + main_layout->addLayout(aux_layout); + conductor_tab_widget -> setLayout (main_layout); - // Folio Tab - tab_widget->addTab(folio_tab_widget, tr("Folio")); + // Folio Tab + tab_widget->addTab(folio_tab_widget, tr("Folio")); - QHBoxLayout *context_layout_2 = new QHBoxLayout(); - context_layout_2 -> addWidget (m_label_2); - context_layout_2 -> addWidget (m_context_cb_2); - context_layout_2 -> addWidget (m_remove_pb_2); + QHBoxLayout *context_layout_2 = new QHBoxLayout(); + context_layout_2 -> addWidget (m_label_2); + context_layout_2 -> addWidget (m_context_cb_2); + context_layout_2 -> addWidget (m_remove_pb_2); - QVBoxLayout *main_layout_2 = new QVBoxLayout(); - QVBoxLayout *aux_layout_2 = new QVBoxLayout(); - aux_layout_2->addLayout(context_layout_2); - aux_layout_2->addWidget(m_saw_2); + QVBoxLayout *main_layout_2 = new QVBoxLayout(); + QVBoxLayout *aux_layout_2 = new QVBoxLayout(); + aux_layout_2->addLayout(context_layout_2); + aux_layout_2->addWidget(m_saw_2); - main_layout_2->addLayout(aux_layout_2); - folio_tab_widget -> setLayout (main_layout_2); + main_layout_2->addLayout(aux_layout_2); + folio_tab_widget -> setLayout (main_layout_2); - //Auto Numbering Tab - Needs Further Testing -// tab_widget->addTab(autoNumbering_tab_widget,tr ("Folio Auto Numbering")); + //Auto Numbering Tab + tab_widget->addTab(autoNumbering_tab_widget,tr ("Folio Auto Numbering")); + + tab_widget->resize(440,590); } /** @@ -337,7 +339,7 @@ void ProjectAutoNumConfigPage::initLayout() { * Read value stored on project, and update display */ void ProjectAutoNumConfigPage::readValuesFromProject() { - //Conductor Tab + //Conductor Tab QList keys = project_->conductorAutoNum().keys(); if (!keys.isEmpty()){ foreach (QString str, keys) { m_context_cb -> addItem(str); } @@ -349,8 +351,8 @@ void ProjectAutoNumConfigPage::readValuesFromProject() { foreach (QString str, keys_2) { m_context_cb_2 -> addItem(str);} } - //Folio AutoNumbering Tab - Needs Further Testing -// m_faw->setContext(keys_2); + //Folio AutoNumbering Tab + m_faw->setContext(keys_2); } /** @@ -370,18 +372,17 @@ void ProjectAutoNumConfigPage::buildConnections() { //Conductor Tab connect (m_context_cb, SIGNAL (currentIndexChanged(QString)), this, SLOT (updateContext(QString))); - connect (m_saw, SIGNAL (applyPressed()), this, SLOT (saveContext())); - connect (m_remove_pb, SIGNAL (clicked()), this, SLOT(removeContext())); + connect (m_saw, SIGNAL (applyPressed()), this, SLOT (saveContext())); + connect (m_remove_pb, SIGNAL (clicked()), this, SLOT(removeContext())); //Folio Tab connect (m_context_cb_2, SIGNAL (currentIndexChanged(QString)), this, SLOT (updateContext_2(QString))); - connect (m_saw_2, SIGNAL (applyPressed()), this, SLOT (saveContext_2())); - connect (m_remove_pb_2, SIGNAL (clicked()), this, SLOT (removeContext_2())); + connect (m_saw_2, SIGNAL (applyPressed()), this, SLOT (saveContext_2())); + connect (m_remove_pb_2, SIGNAL (clicked()), this, SLOT (removeContext_2())); -/* //Auto Folio Numbering - Needs Further Testing - connect (m_faw, SIGNAL (applyPressed()), this, SLOT (applyAutoNum())); + // Auto Folio Numbering + connect (m_faw, SIGNAL (applyPressed()), this, SLOT (applyAutoNum())); connect (m_faw, SIGNAL (m_autonumber_tabs_rb_clicked()), this, SLOT (tabChanged(int))); -*/ } /** @@ -400,8 +401,8 @@ void ProjectAutoNumConfigPage::updateContext(QString str) { * @param str, key of context stored in project */ void ProjectAutoNumConfigPage::updateContext_2(QString str) { - if (str == tr("Nom de la nouvelle numérotation")) m_saw_2 -> setContext(NumerotationContext()); - else m_saw_2 ->setContext(project_->folioAutoNum(str)); + if (str == tr("Nom de la nouvelle numérotation")) m_saw_2 -> setContext(NumerotationContext()); + else m_saw_2 ->setContext(project_->folioAutoNum(str)); } /** @@ -431,48 +432,47 @@ void ProjectAutoNumConfigPage::saveContext() { * Save the current displayed folio context in project */ void ProjectAutoNumConfigPage::saveContext_2() { - // If the text is the default text "Name of new numerotation" save the edited context - // With the the name "No name" - if (m_context_cb_2 -> currentText() == tr("Nom de la nouvelle numérotation")) { - project_->addFolioAutoNum (tr("Sans nom"), m_saw_2 -> toNumContext()); - m_context_cb_2 -> addItem(tr("Sans nom")); - } - // If the text isn't yet to the autonum of the project, add this new item to the combo box. - else if ( !project_ -> folioAutoNum().keys().contains( m_context_cb_2->currentText())) { - project()->addFolioAutoNum(m_context_cb_2->currentText(), m_saw_2->toNumContext()); - m_context_cb_2 -> addItem(m_context_cb_2->currentText()); - } - // Else, the text already exist in the autonum of the project, just update the context - else { - project_->addFolioAutoNum (m_context_cb_2 -> currentText(), m_saw_2 -> toNumContext()); - } + // If the text is the default text "Name of new numerotation" save the edited context + // With the the name "No name" + if (m_context_cb_2 -> currentText() == tr("Nom de la nouvelle numérotation")) { + project_->addFolioAutoNum (tr("Sans nom"), m_saw_2 -> toNumContext()); + m_context_cb_2 -> addItem(tr("Sans nom")); + } + // If the text isn't yet to the autonum of the project, add this new item to the combo box. + else if ( !project_ -> folioAutoNum().keys().contains( m_context_cb_2->currentText())) { + project()->addFolioAutoNum(m_context_cb_2->currentText(), m_saw_2->toNumContext()); + m_context_cb_2 -> addItem(m_context_cb_2->currentText()); + } + // Else, the text already exist in the autonum of the project, just update the context + else { + project_->addFolioAutoNum (m_context_cb_2 -> currentText(), m_saw_2 -> toNumContext()); + } } /** * @brief ProjectAutoNumConfigPage::applyAutoNum * Apply auto folio numbering, New Folios or Selected Folios */ -/* void ProjectAutoNumConfigPage::applyAutoNum() { - if (m_faw->newFolios){ - int foliosRemaining = m_faw->newFoliosNumber(); - emit (saveCurrentTbp()); - emit (setAutoNum(m_faw->autoNumSelected())); - while (foliosRemaining > 0){ - project()->autoFolioNumberingNewFolios(); - foliosRemaining = foliosRemaining-1; - } - emit (loadSavedTbp()); - } - else{ + if (m_faw->newFolios){ + int foliosRemaining = m_faw->newFoliosNumber(); + emit (saveCurrentTbp()); + emit (setAutoNum(m_faw->autoNumSelected())); + while (foliosRemaining > 0){ + qDebug() << foliosRemaining; + project()->autoFolioNumberingNewFolios(); + foliosRemaining = foliosRemaining-1; + } + emit (loadSavedTbp()); + } + else{ QString autoNum = m_faw->autoNumSelected(); int fromFolio = m_faw->fromFolio(); int toFolio = m_faw->toFolio(); project_->autoFolioNumberingSelectedFolios(fromFolio,toFolio,autoNum); - } + } } -*/ /** * @brief ProjectAutoNumConfigPage::removeContext @@ -481,18 +481,18 @@ void ProjectAutoNumConfigPage::applyAutoNum() { void ProjectAutoNumConfigPage::removeContext() { //if default text, return if ( m_context_cb -> currentText() == tr("Nom de la nouvelle numérotation") ) return; - project_ -> removeConductorAutonum (m_context_cb -> currentText() ); - m_context_cb -> removeItem (m_context_cb -> currentIndex() ); + project_ -> removeConductorAutonum (m_context_cb -> currentText() ); + m_context_cb -> removeItem (m_context_cb -> currentIndex() ); } /** * @brief ProjectAutoNumConfigPage::removeContext_2 * Remove from project the current folio numerotation context */ void ProjectAutoNumConfigPage::removeContext_2() { - //if default text, return - if ( m_context_cb_2 -> currentText() == tr("Nom de la nouvelle numérotation") ) return; - project_ -> removeFolioAutoNum (m_context_cb_2 -> currentText() ); - m_context_cb_2 -> removeItem (m_context_cb_2 -> currentIndex() ); + //if default text, return + if ( m_context_cb_2 -> currentText() == tr("Nom de la nouvelle numérotation") ) return; + project_ -> removeFolioAutoNum (m_context_cb_2 -> currentText() ); + m_context_cb_2 -> removeItem (m_context_cb_2 -> currentIndex() ); } /** * @brief ProjectAutoNumConfigPage::changeToTab @@ -500,7 +500,7 @@ void ProjectAutoNumConfigPage::removeContext_2() { * Change to Selected Tab */ void ProjectAutoNumConfigPage::changeToTab(int i){ - tab_widget->setCurrentIndex(i); + tab_widget->setCurrentIndex(i); } /** @@ -514,7 +514,7 @@ void ProjectAutoNumConfigPage::tabChanged(int i){ tab_widget->resize(470,tab_widget->height()); } else { - tab_widget->adjustSize(); + tab_widget->resize(440,tab_widget->height()); } } } diff --git a/sources/projectconfigpages.h b/sources/projectconfigpages.h index d056803fa..9bdd49508 100644 --- a/sources/projectconfigpages.h +++ b/sources/projectconfigpages.h @@ -147,7 +147,7 @@ class ProjectAutoNumConfigPage : public ProjectConfigPage { void saveContext_2(); void removeContext_2(); -// void applyAutoNum(); - Needs Further Testing + void applyAutoNum(); void tabChanged(int); diff --git a/sources/projectview.cpp b/sources/projectview.cpp index 0d572d478..af46e5ca4 100644 --- a/sources/projectview.cpp +++ b/sources/projectview.cpp @@ -77,11 +77,10 @@ QETProject *ProjectView::project() { void ProjectView::setProject(QETProject *project) { if (!project_) { project_ = project; - connect(project_, SIGNAL(projectTitleChanged(QETProject *, const QString &)), this, SLOT(updateWindowTitle())); - connect(project_, SIGNAL(projectModified (QETProject *, bool)), this, SLOT(updateWindowTitle())); - connect(project_, SIGNAL(readOnlyChanged (QETProject *, bool)), this, SLOT(adjustReadOnlyState())); - connect(project_, SIGNAL(addAutoNumDiagram()), this, SLOT(addNewDiagram())); - connect(project_, SIGNAL(addAutoNumDiagram()), this, SLOT(addNewDiagram())); + connect(project_, SIGNAL(projectTitleChanged(QETProject *, const QString &)), this, SLOT(updateWindowTitle())); + connect(project_, SIGNAL(projectModified (QETProject *, bool)), this, SLOT(updateWindowTitle())); + connect(project_, SIGNAL(readOnlyChanged (QETProject *, bool)), this, SLOT(adjustReadOnlyState())); + connect(project_, SIGNAL(addAutoNumDiagram()), this, SLOT(addNewDiagram())); adjustReadOnlyState(); loadDiagrams(); } diff --git a/sources/ui/folioautonumbering.cpp b/sources/ui/folioautonumbering.cpp index 67cb918f9..c523c8e34 100644 --- a/sources/ui/folioautonumbering.cpp +++ b/sources/ui/folioautonumbering.cpp @@ -20,23 +20,22 @@ #include #include #include -#include "qdebug.h" #include "qetproject.h" #include "diagram.h" /** * Constructor */ FolioAutonumberingW::FolioAutonumberingW(QETProject *project, QWidget *parent) : - QWidget(parent), - project_(project), - ui(new Ui::FolioAutonumberingW) + QWidget(parent), + project_(project), + ui(new Ui::FolioAutonumberingW) { - ui->setupUi(this); - applyEnable(false); - ui->m_from_cb->setEnabled(false); - ui->m_new_tabs_sb->setEnabled(false); - ui->m_to_cb->setEnabled(false); + ui->setupUi(this); + applyEnable(false); + ui->m_from_cb->setEnabled(false); + ui->m_new_tabs_sb->setEnabled(false); + ui->m_to_cb->setEnabled(false); } /** @@ -52,7 +51,7 @@ FolioAutonumberingW::~FolioAutonumberingW() * construct autonums in the comboBox selected in the @autonum_chooser QcomboBox */ void FolioAutonumberingW::setContext(QList autonums) { - foreach (QString str, autonums) { ui->m_autonums_cb->addItem(str);} + foreach (QString str, autonums) { ui->m_autonums_cb->addItem(str);} } /** @@ -60,7 +59,7 @@ void FolioAutonumberingW::setContext(QList autonums) { * returns the current autonum selected */ QString FolioAutonumberingW::autoNumSelected(){ - return ui->m_autonums_cb->currentText(); + return ui->m_autonums_cb->currentText(); } /** @@ -84,7 +83,7 @@ int FolioAutonumberingW::toFolio(){ * returns the number of folios to create */ int FolioAutonumberingW::newFoliosNumber(){ - return ui->m_new_tabs_sb->value(); + return ui->m_new_tabs_sb->value(); } /** @@ -92,9 +91,9 @@ int FolioAutonumberingW::newFoliosNumber(){ * update Folio List in From and To ComboBox */ void FolioAutonumberingW::updateFolioList(){ - ui -> m_from_cb->clear(); - ui -> m_to_cb->clear(); - if (newFolios){ + ui -> m_from_cb->clear(); + ui -> m_to_cb->clear(); + if (newFolios){ this -> on_m_create_new_tabs_rb_clicked(); } else { this -> on_m_autonumber_tabs_rb_clicked(); @@ -106,11 +105,11 @@ void FolioAutonumberingW::updateFolioList(){ * Enable New Tabs SpinBox */ void FolioAutonumberingW::on_m_create_new_tabs_rb_clicked() { - ui->m_from_cb->setEnabled(false); - ui->m_to_cb->setEnabled(false); - ui->m_new_tabs_sb->setEnabled(true); - applyEnable(); - newFolios = true; + ui->m_from_cb->setEnabled(false); + ui->m_to_cb->setEnabled(false); + ui->m_new_tabs_sb->setEnabled(true); + applyEnable(); + newFolios = true; } /** @@ -118,18 +117,18 @@ void FolioAutonumberingW::on_m_create_new_tabs_rb_clicked() { * Enable From ComboBox, fill From ComboBox */ void FolioAutonumberingW::on_m_autonumber_tabs_rb_clicked() { - ui->m_new_tabs_sb->setEnabled(false); - ui->m_from_cb->setEnabled(true); - ui->m_to_cb->setEnabled(true); - if (ui->m_from_cb->count()<=0){ - ui->m_from_cb->clear(); - ui->m_from_cb->addItem(""); - foreach (Diagram *diagram, project_->diagrams()){ - ui->m_from_cb->addItem(diagram->title()); - } - } - applyEnable(); - newFolios = false; + ui->m_new_tabs_sb->setEnabled(false); + ui->m_from_cb->setEnabled(true); + ui->m_to_cb->setEnabled(true); + if (ui->m_from_cb->count()<=0){ + ui->m_from_cb->clear(); + ui->m_from_cb->addItem(""); + foreach (Diagram *diagram, project_->diagrams()){ + ui->m_from_cb->addItem(diagram->title()); + } + } + applyEnable(); + newFolios = false; } /** @@ -137,8 +136,8 @@ void FolioAutonumberingW::on_m_autonumber_tabs_rb_clicked() { * Enable Apply if any new folio is to be created */ void FolioAutonumberingW::on_m_new_tabs_sb_valueChanged(){ - if (ui->m_new_tabs_sb->value()>0) applyEnable(true); - else applyEnable(false); + if (ui->m_new_tabs_sb->value()>0) applyEnable(true); + else applyEnable(false); } /** @@ -146,17 +145,17 @@ void FolioAutonumberingW::on_m_new_tabs_sb_valueChanged(){ * Enable To ComboBox */ void FolioAutonumberingW::on_m_from_cb_currentIndexChanged(){ - int index = ui->m_from_cb->currentIndex(); - ui->m_to_cb->clear(); - if (index > 0){ - ui->m_to_cb->setEnabled(true); - for (int i=index;idiagrams().size();i++) - ui->m_to_cb->addItem(project_->diagrams().at(i)->title()); - applyEnable(true); - } - else{ - applyEnable(); - } + int index = ui->m_from_cb->currentIndex(); + ui->m_to_cb->clear(); + if (index > 0){ + ui->m_to_cb->setEnabled(true); + for (int i=index;idiagrams().size();i++) + ui->m_to_cb->addItem(project_->diagrams().at(i)->title()); + applyEnable(true); + } + else{ + applyEnable(); + } } @@ -165,35 +164,34 @@ void FolioAutonumberingW::on_m_from_cb_currentIndexChanged(){ * Action on @buttonBox clicked */ void FolioAutonumberingW::on_buttonBox_clicked(QAbstractButton *button) { - //transform button to int + //transform button to int int answer = ui -> buttonBox -> buttonRole(button); - switch (answer) { + switch (answer) { //help dialog - not implemented yet - case QDialogButtonBox::HelpRole: - break; - /*QMessageBox::information (this, tr("Folio Autonumbering", "title window"), - tr("C'est ici que vous pouvez définir la manière dont sera numéroté les nouveaux conducteurs.\n" + QMessageBox::information (this, tr("Folio Autonumbering", "title window"), + tr("C'est ici que vous pouvez définir la manière dont sera numéroté les nouveaux folios.\n" "-Une numérotation est composée d'une variable minimum.\n" "-Vous pouvez ajouter ou supprimer une variable de numérotation par le biais des boutons - et +.\n" "-Une variable de numérotation comprant: un type, une valeur et une incrémentation.\n" "\n-les types \"Chiffre 1\", \"Chiffre 01\" et \"Chiffre 001\", représente un type numérique définie dans le champs \"Valeur\", " - "qui s'incrémente à chaque nouveau conducteur de la valeur du champ \"Incrémentation\".\n" + "qui s'incrémente à chaque nouveau folio de la valeur du champ \"Incrémentation\".\n" "-\"Chiffre 01\" et \"Chiffre 001\", sont respectivement représenté sur le schéma par deux et trois digits minimum.\n" "Si le chiffre définie dans le champs Valeur posséde moins de digits que le type choisit," "celui-ci sera précédé par un ou deux 0 afin de respecter son type.\n" - "\n-Le type \"Texte\", représente un texte fixe.\nLe champs \"Incrémentation\" n'est pas utilisé.\n" - - "\n-Le type \"N° folio\" représente le n° du folio en cours.\nLes autres champs ne sont pas utilisés.", - "help dialog about the autonumerotation")); */ - case QDialogButtonBox::ApplyRole: - applyEnable(true); - emit applyPressed(); - updateFolioList(); + "\n-Le type \"Texte\", représente un texte fixe.\nLe champs \"Incrémentation\" n'est pas utilisé.\n", + "help dialog about the folio autonumerotation" + )); break; - } + case QDialogButtonBox::ApplyRole: + applyEnable(true); + emit applyPressed(); + updateFolioList(); + break; + } } /** @@ -201,18 +199,18 @@ void FolioAutonumberingW::on_buttonBox_clicked(QAbstractButton *button) { * enable/disable the apply button */ void FolioAutonumberingW::applyEnable(bool b) { - if (b){ - bool valid = true; - if (ui->m_create_new_tabs_rb->isChecked()){ - if (ui->m_new_tabs_sb->value()==0) valid = false; - ui->buttonBox->button(QDialogButtonBox::Apply)->setEnabled(valid); - } - else{ - if (ui->m_to_cb->currentText()=="") valid = false; - ui->buttonBox->button(QDialogButtonBox::Apply)->setEnabled(valid); - } - } - else{ - ui -> buttonBox -> button(QDialogButtonBox::Apply) -> setEnabled(b); - } + if (b){ + bool valid = true; + if (ui->m_create_new_tabs_rb->isChecked()){ + if (ui->m_new_tabs_sb->value()==0) valid = false; + ui->buttonBox->button(QDialogButtonBox::Apply)->setEnabled(valid); + } + else{ + if (ui->m_to_cb->currentText()=="") valid = false; + ui->buttonBox->button(QDialogButtonBox::Apply)->setEnabled(valid); + } + } + else{ + ui -> buttonBox -> button(QDialogButtonBox::Apply) -> setEnabled(b); + } } diff --git a/sources/ui/folioautonumbering.ui b/sources/ui/folioautonumbering.ui index 2d0601426..043d1aef9 100644 --- a/sources/ui/folioautonumbering.ui +++ b/sources/ui/folioautonumbering.ui @@ -129,7 +129,7 @@ - New Tabs + New Folios @@ -212,7 +212,7 @@ - Create New Tabs + Create New Folios @@ -225,7 +225,7 @@ - Autonumber Selected Tabs + Autonumber Selected Folios @@ -284,7 +284,7 @@ - QDialogButtonBox::Apply|QDialogButtonBox::Help|QDialogButtonBox::Reset + QDialogButtonBox::Apply diff --git a/sources/ui/numparteditorw.cpp b/sources/ui/numparteditorw.cpp index 89553beab..3cb06a431 100644 --- a/sources/ui/numparteditorw.cpp +++ b/sources/ui/numparteditorw.cpp @@ -28,6 +28,7 @@ NumPartEditorW::NumPartEditorW(QWidget *parent) : intValidator (new QIntValidator(0,99999,this)) { ui -> setupUi(this); + if (parentWidget()->parentWidget()->objectName()=="FolioTab") ui->type_combo->setMaxCount(4); setType(NumPartEditorW::unit, true); } @@ -41,7 +42,7 @@ NumPartEditorW::NumPartEditorW (NumerotationContext &context, int i, QWidget *pa intValidator (new QIntValidator(0,99999,this)) { ui -> setupUi(this); - + if (parentWidget()->parentWidget()->objectName()=="FolioTab") ui->type_combo->setMaxCount(5); //if @context contains nothing build with default value if(context.size()==0) setType(NumPartEditorW::unit, true); @@ -51,7 +52,8 @@ NumPartEditorW::NumPartEditorW (NumerotationContext &context, int i, QWidget *pa else if (strl.at(0)=="ten") setType(NumPartEditorW::ten, true); else if (strl.at(0)=="hundred") setType(NumPartEditorW::hundred, true); else if (strl.at(0)=="string") setType(NumPartEditorW::string); - else if (strl.at(0)== "folio") setType(NumPartEditorW::folio); + else if (strl.at(0)=="idfolio") setType(NumPartEditorW::idfolio); + else if (strl.at(0)=="folio") setType(NumPartEditorW::folio); ui -> value_field -> setText(strl.at(1)); ui -> increase_spinBox -> setValue(strl.at(2).toInt()); } @@ -86,6 +88,9 @@ NumerotationContext NumPartEditorW::toNumContext() { case string: type_str = "string"; break; + case idfolio: + type_str = "idfolio"; + break; case folio: type_str = "folio"; break; @@ -99,8 +104,9 @@ NumerotationContext NumPartEditorW::toNumContext() { * @return true if value field isn't empty or if type is folio */ bool NumPartEditorW::isValid() { - if (type_ != folio && ui -> value_field -> text().isEmpty()) return false; - return true; + if (type_ == folio||type_ == idfolio) {return true;} + else if(ui -> value_field -> text().isEmpty()) {return false;} + else return true; } /** @@ -121,6 +127,9 @@ void NumPartEditorW::on_type_combo_activated(int index) { case string: setType(string); break; + case idfolio: + setType(idfolio); + break; case folio: setType(folio); break; @@ -155,7 +164,7 @@ void NumPartEditorW::setType(NumPartEditorW::type t, bool fnum) { //if @t is a numeric type and preview type @type_ isn't a numeric type //or @fnum is true, we set numeric behavior - if ( ((t==unit || t==ten || t==hundred) && (type_==string || type_==folio)) || fnum) { + if ( ((t==unit || t==ten || t==hundred) && (type_==string || type_==folio || type_==idfolio)) || fnum) { ui -> value_field -> clear(); ui -> value_field -> setEnabled(true); ui -> value_field -> setValidator(intValidator); @@ -163,7 +172,7 @@ void NumPartEditorW::setType(NumPartEditorW::type t, bool fnum) { ui -> increase_spinBox -> setValue(1); } //@t isn't a numeric type - else if (t==string || t==folio) { + else if (t==string || t==folio || t==idfolio) { ui -> value_field -> clear(); ui -> increase_spinBox -> setDisabled(true); if (t==string) { @@ -174,6 +183,10 @@ void NumPartEditorW::setType(NumPartEditorW::type t, bool fnum) { ui -> value_field -> setDisabled(true); ui -> increase_spinBox -> setDisabled(true); } + else if (t==idfolio) { + ui -> value_field -> setDisabled(true); + ui -> increase_spinBox -> setDisabled(true); + } } type_= t; } diff --git a/sources/ui/numparteditorw.h b/sources/ui/numparteditorw.h index 07bb177a6..7ca0c25f7 100644 --- a/sources/ui/numparteditorw.h +++ b/sources/ui/numparteditorw.h @@ -41,7 +41,7 @@ class NumPartEditorW : public QWidget NumPartEditorW (NumerotationContext &, int, QWidget *parent=0); ~NumPartEditorW(); - enum type {unit,ten,hundred,string,folio}; + enum type {unit,ten,hundred,string,idfolio,folio}; NumerotationContext toNumContext(); bool isValid (); diff --git a/sources/ui/numparteditorw.ui b/sources/ui/numparteditorw.ui index a5ff122d9..15e9a5f59 100644 --- a/sources/ui/numparteditorw.ui +++ b/sources/ui/numparteditorw.ui @@ -6,8 +6,8 @@ 0 0 - 259 - 42 + 308 + 45 @@ -28,6 +28,9 @@ 0 + + true + Chiffre 1 @@ -53,6 +56,11 @@ N° folio + + + Folio + + diff --git a/sources/ui/selectautonumw.cpp b/sources/ui/selectautonumw.cpp index f20509ed4..6c677657a 100644 --- a/sources/ui/selectautonumw.cpp +++ b/sources/ui/selectautonumw.cpp @@ -19,7 +19,6 @@ #include "ui_selectautonumw.h" #include "numparteditorw.h" #include -#include "qdebug.h" #include "numerotationcontextcommands.h" /** @@ -125,7 +124,6 @@ void SelectAutonumW::on_remove_button_clicked() { void SelectAutonumW::on_buttonBox_clicked(QAbstractButton *button) { //transform button to int int answer = ui -> buttonBox -> buttonRole(button); - switch (answer) { //Reset the curent context case QDialogButtonBox::ResetRole: @@ -133,23 +131,46 @@ void SelectAutonumW::on_buttonBox_clicked(QAbstractButton *button) { break; //help dialog case QDialogButtonBox::HelpRole: - QMessageBox::information (this, tr("Autonumérotation", "title window"), - tr("C'est ici que vous pouvez définir la manière dont sera numéroté les nouveaux conducteurs.\n" - "-Une numérotation est composée d'une variable minimum.\n" - "-Vous pouvez ajouter ou supprimer une variable de numérotation par le biais des boutons - et +.\n" - "-Une variable de numérotation comprant: un type, une valeur et une incrémentation.\n" + if (this->parentWidget() -> objectName()=="FolioTab"){ + QMessageBox::information (this, tr("Folio Autonumérotation", "title window"), + tr("C'est ici que vous pouvez définir la manière dont sera numéroté les nouveaux folios.\n" + "-Une numérotation est composée d'une variable minimum.\n" + "-Vous pouvez ajouter ou supprimer une variable de numérotation par le biais des boutons - et +.\n" + "-Une variable de numérotation comprant: un type, une valeur et une incrémentation.\n" - "\n-les types \"Chiffre 1\", \"Chiffre 01\" et \"Chiffre 001\", représente un type numérique définie dans le champs \"Valeur\", " - "qui s'incrémente à chaque nouveau conducteur de la valeur du champ \"Incrémentation\".\n" - "-\"Chiffre 01\" et \"Chiffre 001\", sont respectivement représenté sur le schéma par deux et trois digits minimum.\n" - "Si le chiffre définie dans le champs Valeur posséde moins de digits que le type choisit," - "celui-ci sera précédé par un ou deux 0 afin de respecter son type.\n" + "\n-les types \"Chiffre 1\", \"Chiffre 01\" et \"Chiffre 001\", représente un type numérique définie dans le champs \"Valeur\", " + "qui s'incrémente à chaque nouveau folio de la valeur du champ \"Incrémentation\".\n" + "-\"Chiffre 01\" et \"Chiffre 001\", sont respectivement représenté sur le schéma par deux et trois digits minimum.\n" + "Si le chiffre définie dans le champs Valeur posséde moins de digits que le type choisit," + "celui-ci sera précédé par un ou deux 0 afin de respecter son type.\n" - "\n-Le type \"Texte\", représente un texte fixe.\nLe champs \"Incrémentation\" n'est pas utilisé.\n" + "\n-Le type \"Texte\", représente un texte fixe.\nLe champs \"Incrémentation\" n'est pas utilisé.\n", + "help dialog about the folio autonumerotation" + )); + break; + } + else{ + QMessageBox::information (this, tr("Conductor Autonumérotation", "title window"), + tr("C'est ici que vous pouvez définir la manière dont sera numéroté les nouveaux conducteurs.\n" + "-Une numérotation est composée d'une variable minimum.\n" + "-Vous pouvez ajouter ou supprimer une variable de numérotation par le biais des boutons - et +.\n" + "-Une variable de numérotation comprant: un type, une valeur et une incrémentation.\n" - "\n-Le type \"N° folio\" représente le n° du folio en cours.\nLes autres champs ne sont pas utilisés.", - "help dialog about the autonumerotation")); + "\n-les types \"Chiffre 1\", \"Chiffre 01\" et \"Chiffre 001\", représente un type numérique définie dans le champs \"Valeur\", " + "qui s'incrémente à chaque nouveau conducteur de la valeur du champ \"Incrémentation\".\n" + "-\"Chiffre 01\" et \"Chiffre 001\", sont respectivement représenté sur le schéma par deux et trois digits minimum.\n" + "Si le chiffre définie dans le champs Valeur posséde moins de digits que le type choisit," + "celui-ci sera précédé par un ou deux 0 afin de respecter son type.\n" + "\n-Le type \"Texte\", représente un texte fixe.\nLe champs \"Incrémentation\" n'est pas utilisé.\n" + + "\n-Le type \"N° folio\" représente le n° du folio en cours.\nLes autres champs ne sont pas utilisés.\n" + + "\n-Le type \"Folio\" représente le nom du folio en cours.\nLes autres champs ne sont pas utilisés.", + "help dialog about the conductor autonumerotation" + )); + break; + } //apply the context in the diagram displayed by @diagram_chooser. case QDialogButtonBox::ApplyRole: applyEnable(false); diff --git a/sources/ui/selectautonumw.ui b/sources/ui/selectautonumw.ui index a2630d8ec..c644bd9c2 100644 --- a/sources/ui/selectautonumw.ui +++ b/sources/ui/selectautonumw.ui @@ -6,12 +6,12 @@ 0 0 - 466 + 418 506 - + 0 0 @@ -23,14 +23,14 @@ - + 0 0 - 430 + 400 455 @@ -66,19 +66,19 @@ 0 0 - 460 + 400 453 - + 0 0 - 460 + 400 450 @@ -89,7 +89,7 @@ - + 0 0