[qet] [4573] Added AutoNumbering Dock Widget

[ Thread Index | Date Index | More lists.tuxfamily.org/qet Archives ]


Revision: 4573
Author:   dfochi
Date:     2016-07-13 16:57:27 +0200 (Wed, 13 Jul 2016)
Log Message:
-----------
Added AutoNumbering Dock Widget

Modified Paths:
--------------
    trunk/sources/bordertitleblock.cpp
    trunk/sources/bordertitleblock.h
    trunk/sources/configpages.cpp
    trunk/sources/projectconfigpages.cpp
    trunk/sources/qetdiagrameditor.cpp
    trunk/sources/qetdiagrameditor.h
    trunk/sources/qetproject.cpp
    trunk/sources/qetproject.h
    trunk/sources/titleblockproperties.h
    trunk/sources/ui/diagrampropertiesdialog.cpp

Added Paths:
-----------
    trunk/sources/ui/autonumberingdockwidget.cpp
    trunk/sources/ui/autonumberingdockwidget.h
    trunk/sources/ui/autonumberingdockwidget.ui

Modified: trunk/sources/bordertitleblock.cpp
===================================================================
--- trunk/sources/bordertitleblock.cpp	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/bordertitleblock.cpp	2016-07-13 14:57:27 UTC (rev 4573)
@@ -260,7 +260,7 @@
 	setTitle(ip.title);
 	setFileName(ip.filename);
 	setFolio(ip.folio);
-    setAutoPageNum(ip.auto_page_num);
+	setAutoPageNum(ip.auto_page_num);
 	if (m_edge != ip.display_at)
 	{
 		m_edge = ip.display_at;
@@ -395,6 +395,15 @@
 }
 
 /**
+ * @brief BorderTitleBlock::slot_setAutoPageNum
+ * @param pageAutoNum
+ * Set Page (Folio) Auto Num
+ */
+void BorderTitleBlock::slot_setAutoPageNum(QString pageAutoNum) {
+	btb_auto_page_num_=pageAutoNum;
+}
+
+/**
  * @brief BorderTitleBlock::updateRectangles
  * This method update the diagram rect according to the value of rows and columns (number and size)
  */

Modified: trunk/sources/bordertitleblock.h
===================================================================
--- trunk/sources/bordertitleblock.h	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/bordertitleblock.h	2016-07-13 14:57:27 UTC (rev 4573)
@@ -168,6 +168,7 @@
 	void displayColumns(bool);
 	void displayRows(bool);
 	void displayBorder(bool);
+	void slot_setAutoPageNum (QString);
 	
 	private:
 	void updateRectangles();

Modified: trunk/sources/configpages.cpp
===================================================================
--- trunk/sources/configpages.cpp	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/configpages.cpp	2016-07-13 14:57:27 UTC (rev 4573)
@@ -161,6 +161,7 @@
 			xrp.toSettings(settings, str += key);
 		}
 	}
+	emit (m_project->defaultTitleBlockPropertiesChanged());
 }
 
 /**

Modified: trunk/sources/projectconfigpages.cpp
===================================================================
--- trunk/sources/projectconfigpages.cpp	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/projectconfigpages.cpp	2016-07-13 14:57:27 UTC (rev 4573)
@@ -479,6 +479,7 @@
 	else {
 		project_->addConductorAutoNum (m_context_cb_conductor-> currentText(), m_saw_conductor -> toNumContext());
 	}
+	project()->conductorAutoNumAdded();
 }
 
 /**
@@ -501,6 +502,7 @@
 	else {
 		project_->addFolioAutoNum (m_context_cb_folio -> currentText(), m_saw_folio -> toNumContext());
 	}
+	project()->folioAutoNumAdded();
 }
 
 /**
@@ -514,22 +516,23 @@
 	if (m_context_cb_element -> currentText() == tr("Nom de la nouvelle numérotation")) {
 		project_->addElementAutoNum (tr("Sans nom"), m_saw_element -> toNumContext());
 		project()->addElementAutoNumFormula (tr("Sans nom"), m_saw_element->elementFormula()); //add hash <title, formula>
-		project()->addElementAutoNumCurrentFormula (m_saw_element->elementFormula()); //add last added element formula to current formula
+		project()->setElementAutoNumCurrentFormula (m_saw_element->elementFormula()); //add last added element formula to current formula
 		m_context_cb_element -> 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_ -> elementAutoNum().keys().contains( m_context_cb_element->currentText())) {
 		project()->addElementAutoNum(m_context_cb_element->currentText(), m_saw_element->toNumContext()); //add hash <title, numcontext>
 		project()->addElementAutoNumFormula (m_context_cb_element->currentText(), m_saw_element->elementFormula()); //add hash <title, formula>
-		project()->addElementAutoNumCurrentFormula (m_saw_element->elementFormula()); //add last added element formula to current formula
+		project()->setElementAutoNumCurrentFormula (m_saw_element->elementFormula()); //add last added element formula to current formula
 		m_context_cb_element -> addItem(m_context_cb_element->currentText());
 	}
 	// Else, the text already exist in the autonum of the project, just update the context
 	else {
 		project_->addElementAutoNum (m_context_cb_element -> currentText(), m_saw_element -> toNumContext()); //add hash <title, numcontext>
 		project()->addElementAutoNumFormula (m_context_cb_element->currentText(), m_saw_element->elementFormula()); //add hash <title, formula>
-		project()->addElementAutoNumCurrentFormula (m_saw_element->elementFormula()); //add last added element formula to current formula
+		project()->setElementAutoNumCurrentFormula (m_saw_element->elementFormula()); //add last added element formula to current formula
 	}
+	project()->elementAutoNumAdded();
 }
 
 /**
@@ -565,6 +568,7 @@
 	if ( m_context_cb_conductor-> currentText() == tr("Nom de la nouvelle numérotation") ) return;
 	project_ -> removeConductorAutoNum (m_context_cb_conductor-> currentText() );
 	m_context_cb_conductor-> removeItem (m_context_cb_conductor-> currentIndex() );
+	project()->conductorAutoNumRemoved();
 }
 
 /**
@@ -576,6 +580,7 @@
 	if ( m_context_cb_folio -> currentText() == tr("Nom de la nouvelle numérotation") ) return;
 	project_ -> removeFolioAutoNum (m_context_cb_folio -> currentText() );
 	m_context_cb_folio -> removeItem (m_context_cb_folio -> currentIndex() );
+	project()->folioAutoNumRemoved();
 }
 
 /**
@@ -587,6 +592,7 @@
 	if ( m_context_cb_element -> currentText() == tr("Nom de la nouvelle numérotation") ) return;
 	project_ -> removeElementAutoNum (m_context_cb_element -> currentText() );
 	m_context_cb_element -> removeItem (m_context_cb_element -> currentIndex() );
+	project()->elementAutoNumRemoved();
 }
 
 /**

Modified: trunk/sources/qetdiagrameditor.cpp
===================================================================
--- trunk/sources/qetdiagrameditor.cpp	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/qetdiagrameditor.cpp	2016-07-13 14:57:27 UTC (rev 4573)
@@ -41,6 +41,7 @@
 #include "diagrameventaddimage.h"
 #include "diagrameventaddtext.h"
 #include "elementscollectionwidget.h"
+#include "autonumberingdockwidget.h"
 
 #include "ui/dialogautonum.h"
 
@@ -66,7 +67,8 @@
 	m_file_actions_group       (this),
 	open_dialog_dir            (QStandardPaths::writableLocation(QStandardPaths::DesktopLocation))
 {
-		//Setup the mdi area at center of application
+	activeSubWindowIndex = 0;
+	//Setup the mdi area at center of application
 	setCentralWidget(&workspace);
 	
 		//Set object name to be retrieved by the stylesheets
@@ -85,6 +87,7 @@
 	setUpElementsCollectionWidget();
 	setUpUndoStack();
 	setUpSelectionPropertiesEditor();
+	setUpAutonumberingWidget();
 
 	setUpActions();
 	setUpToolBar();
@@ -206,6 +209,18 @@
 }
 
 /**
+ * @brief QETDiagramEditor::setUpAutonumberingWidget
+ * Setup the dock for AutoNumbering Selection
+ */
+void QETDiagramEditor::setUpAutonumberingWidget()
+{
+	m_autonumbering_dock = new AutoNumberingDockWidget(this);
+	m_autonumbering_dock -> setAllowedAreas(Qt::LeftDockWidgetArea | Qt::RightDockWidgetArea);
+	m_autonumbering_dock -> setFeatures(QDockWidget::AllDockWidgetFeatures);
+	addDockWidget(Qt::RightDockWidgetArea, m_autonumbering_dock);
+}
+
+/**
  * @brief QETDiagramEditor::setUpActions
  * Set up all Qaction
  */
@@ -939,6 +954,7 @@
 	// met a jour le panel d'elements
 	if (update_panel) {
 		pa -> elementsPanel().projectWasOpened(project);
+		m_autonumbering_dock->setProject(project, project_view);
 	}
 	
 	return(true);
@@ -1300,9 +1316,23 @@
 	slot_updateModeActions();
 	slot_updatePasteAction();
 	slot_updateComplexActions();
+	slot_updateAutoNumDock();
 }
 
 /**
+ * @brief QETDiagramEditor::slot_updateAutoNumDock
+ * Update Auto Num Dock Widget when changing Project
+ */
+void QETDiagramEditor::slot_updateAutoNumDock() {
+	if ( workspace.subWindowList().indexOf(workspace.activeSubWindow()) != activeSubWindowIndex) {
+			activeSubWindowIndex = workspace.subWindowList().indexOf(workspace.activeSubWindow());
+			if (currentProject()!=NULL) {
+				m_autonumbering_dock->setProject(currentProject()->project(),currentProject());
+			}
+	}
+}
+
+/**
  * @brief QETDiagramEditor::slot_updateUndoStack
  * Update the undo stack view
  */

Modified: trunk/sources/qetdiagrameditor.h
===================================================================
--- trunk/sources/qetdiagrameditor.h	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/qetdiagrameditor.h	2016-07-13 14:57:27 UTC (rev 4573)
@@ -32,6 +32,7 @@
 class RecentFiles;
 class DiagramPropertiesEditorDockWidget;
 class ElementsCollectionWidget;
+class AutoNumberingDockWidget;
 
 /**
 	This class represents the main window of the QElectroTech diagram editor and,
@@ -53,6 +54,7 @@
 		void setUpElementsCollectionWidget();
 		void setUpUndoStack     ();
 		void setUpSelectionPropertiesEditor();
+		void setUpAutonumberingWidget();
 		void setUpActions       ();
 		void setUpToolBar       ();
 		void setUpMenu          ();
@@ -110,6 +112,7 @@
 		void slot_updateComplexActions();
 		void slot_updatePasteAction();
 		void slot_updateWindowsMenu();
+		void slot_updateAutoNumDock();
 		void editSelectionProperties();
 		void slot_resetConductors();
 		void slot_autoConductor(bool ac);
@@ -151,7 +154,7 @@
 	private slots:
 		void selectionChanged();
 		void activeUndoStackCleanChanged (bool clean);
-	
+
 		// attributes
 	public:
 		// Actions reachable through menus within QElectroTech
@@ -226,5 +229,8 @@
 		QToolBar *diagram_bar;
 		QToolBar *m_add_item_toolBar;
 		QUndoGroup undo_group;
+		// AutoNumbering Selection Dock
+		AutoNumberingDockWidget *m_autonumbering_dock;
+		int activeSubWindowIndex;
 };
 #endif

Modified: trunk/sources/qetproject.cpp
===================================================================
--- trunk/sources/qetproject.cpp	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/qetproject.cpp	2016-07-13 14:57:27 UTC (rev 4573)
@@ -362,6 +362,7 @@
 		QScopedPointer<IntegrationMoveTitleBlockTemplatesHandler> m(new IntegrationMoveTitleBlockTemplatesHandler);
 		integrateTitleBlockTemplate(collection -> location(titleblock.template_name), m.data());
 	}
+	emit defaultTitleBlockPropertiesChanged();
 }
 
 /**
@@ -472,11 +473,11 @@
 }
 
 /**
- * @brief QETProject::addElementAutoNumCurrentFormula
+ * @brief QETProject::setElementAutoNumCurrentFormula
  * Add the formula to the current formula
  * @param formula
  */
-void QETProject::addElementAutoNumCurrentFormula(QString formula) {
+void QETProject::setElementAutoNumCurrentFormula(QString formula) {
 	m_current_element_formula = formula;
 }
 

Modified: trunk/sources/qetproject.h
===================================================================
--- trunk/sources/qetproject.h	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/qetproject.h	2016-07-13 14:57:27 UTC (rev 4573)
@@ -113,7 +113,7 @@
 		void addConductorAutoNum (QString key, NumerotationContext context);
 		void addElementAutoNum (QString key, NumerotationContext context);
 		void addElementAutoNumFormula (QString key, QString formula);
-		void addElementAutoNumCurrentFormula (QString formula);
+		void setElementAutoNumCurrentFormula (QString formula);
 		void addFolioAutoNum     (QString key, NumerotationContext context);
 		void removeConductorAutoNum (QString key);
 		void removeElementAutoNum (QString key);
@@ -171,6 +171,15 @@
 	void reportPropertiesChanged(QString);
 	void XRefPropertiesChanged ();
 	void addAutoNumDiagram();
+	void elementAutoNumAdded();
+	void elementAutoNumRemoved();
+	void conductorAutoNumAdded();
+	void conductorAutoNumRemoved();
+	void folioAutoNumAdded();
+	void folioAutoNumRemoved();
+	void folioAutoNumChanged(QString);
+	void defaultTitleBlockPropertiesChanged();
+	void conductorAutoNumChanged();
 	
 	private slots:
 	void updateDiagramsFolioData();

Modified: trunk/sources/titleblockproperties.h
===================================================================
--- trunk/sources/titleblockproperties.h	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/titleblockproperties.h	2016-07-13 14:57:27 UTC (rev 4573)
@@ -43,6 +43,8 @@
 	void toSettings(QSettings &, const QString & = QString()) const;
 	void fromSettings(QSettings &, const QString & = QString());
 
+	void setAutoPageNum(QString autonum) {auto_page_num = autonum;}
+
 	static TitleBlockProperties defaultProperties();
 	
 	QDate finalDate() const ;
@@ -53,13 +55,13 @@
 	QDate date;               ///< Date (displayed by the default template)
 	QString filename;         ///< Filename (displayed by the default template)
 	QString folio;            ///< Folio information (displayed by the default template)
-    QString auto_page_num;
+	QString auto_page_num;
 	DateManagement useDate;   ///< Wheter to use the date attribute
 	QString template_name;    ///< Name of the template used to render the title block - an empty string means "the default template provided by the application"
 	DiagramContext context;   ///< Container for the additional, user-defined fields
 	Qt::Edge display_at;       ///< Edge to display the titleblock
 	QET::QetCollection collection; ///<Specify the location of the title block
-	
+
 	private:
 	QString exportDate() const;
 	void setDateFromString(const QString &);

Added: trunk/sources/ui/autonumberingdockwidget.cpp
===================================================================
--- trunk/sources/ui/autonumberingdockwidget.cpp	                        (rev 0)
+++ trunk/sources/ui/autonumberingdockwidget.cpp	2016-07-13 14:57:27 UTC (rev 4573)
@@ -0,0 +1,244 @@
+/*
+	Copyright 2006-2016 The QElectroTech Team
+	This file is part of QElectroTech.
+
+	QElectroTech 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 2 of the License, or
+	(at your option) any later version.
+
+	QElectroTech 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 QElectroTech.  If not, see <http://www.gnu.org/licenses/>.
+*/
+#include "autonumberingdockwidget.h"
+#include "qetapp.h"
+#include "ui_autonumberingdockwidget.h"
+#include "diagramview.h"
+#include "diagram.h"
+#include "titleblockproperties.h"
+#include "numerotationcontext.h"
+
+/**
+ * @brief AutoNumberingDockWidget::AutoNumberingDockWidget
+ * Constructor
+ * @param parent : parent widget
+ */
+AutoNumberingDockWidget::AutoNumberingDockWidget(QWidget *parent, QETProject *project) :
+	QDockWidget(parent),
+	ui(new Ui::AutoNumberingDockWidget),
+	project_(project)
+{
+	ui->setupUi(this);
+}
+
+/**
+ * @brief AutoNumberingDockWidget::~AutoNumberingDockWidget
+ * Destructor
+ */
+AutoNumberingDockWidget::~AutoNumberingDockWidget()
+{
+	this->disconnect();
+	delete ui;
+}
+
+/**
+ * @brief AutoNumberingDockWidget::clear
+ * Remove all combo box values
+ */
+void AutoNumberingDockWidget::clear()
+{
+	ui->m_conductor_cb->clear();
+	ui->m_element_cb->clear();
+	ui->m_folio_cb->clear();
+}
+
+/**
+ * @brief AutoNumberingDockWidget::setProject
+ * @param project: project to be setted
+ * @param projectview: projectview to be setted
+ * assign Project and ProjectView, connect all signals and setContext
+ */
+void AutoNumberingDockWidget::setProject(QETProject *project, ProjectView *projectview) {
+
+	project_ = project;
+	projectview_ = projectview;
+
+	//Conductor Signals
+	connect(project_, SIGNAL(conductorAutoNumChanged()),this,SLOT(conductorAutoNumChanged()));
+	connect (project_,SIGNAL(conductorAutoNumRemoved()), this,SLOT(conductorAutoNumChanged()));
+	connect (project_,SIGNAL(conductorAutoNumAdded()),   this,SLOT(conductorAutoNumChanged()));
+	connect(projectview_,SIGNAL(diagramActivated(DiagramView*)),this,SLOT(setConductorActive(DiagramView*)));
+
+	//Element Signals
+	connect (project_,SIGNAL(elementAutoNumRemoved()),   this,SLOT(elementAutoNumChanged()));
+	connect (project_,SIGNAL(elementAutoNumAdded()),     this,SLOT(elementAutoNumChanged()));
+
+	//Folio Signals
+	connect (project_,SIGNAL(folioAutoNumRemoved()),     this,SLOT(folioAutoNumChanged()));
+	connect (project_,SIGNAL(folioAutoNumAdded()),       this,SLOT(folioAutoNumChanged()));
+	connect (this,
+			 SIGNAL(folioAutoNumChanged(QString)),
+			 &projectview_->currentDiagram()->diagram()->border_and_titleblock,
+			 SLOT (slot_setAutoPageNum(QString)));
+	connect(project_, SIGNAL(defaultTitleBlockPropertiesChanged()),this,SLOT(setActive()));
+
+	//Conductor, Element and Folio Signals
+	connect(projectview_,SIGNAL(projectClosed(ProjectView*)),this,SLOT(clear()));
+
+	//Set Combobox Context
+	setContext();
+}
+
+/**
+ * @brief AutoNumberingDockWidget::setContext
+ * Add all itens to comboboxes
+ */
+void AutoNumberingDockWidget::setContext() {
+
+	this->clear();
+
+	//Conductor Combobox
+	QList <QString> keys_conductor = project_->conductorAutoNum().keys();
+	if (!keys_conductor.isEmpty()) {
+		foreach (QString str, keys_conductor) { ui->m_conductor_cb-> addItem(str); }
+	}
+
+	//Element Combobox
+	QList <QString> keys_element = project_->elementAutoNum().keys();
+	if (!keys_element.isEmpty()) {
+		foreach (QString str, keys_element) {ui->m_element_cb -> addItem(str);}
+	}
+
+	//Folio Combobox
+	QList <QString> keys_folio = project_->folioAutoNum().keys();
+	if (!keys_folio.isEmpty()) {
+		foreach (QString str, keys_folio) { ui->m_folio_cb -> addItem(str);}
+	}
+
+	this->setActive();
+}
+
+/**
+ * @brief AutoNumberingDockWidget::setConductorActive
+ * @param dv: activated diagramview
+ */
+void AutoNumberingDockWidget::setConductorActive(DiagramView* dv) {
+	if (dv!=NULL) {
+		QString conductor_autonum = dv->diagram()->conductorsAutonumName();
+		int conductor_index = ui->m_conductor_cb->findText(conductor_autonum);
+		ui->m_conductor_cb->setCurrentIndex(conductor_index);
+	}
+}
+
+/**
+ * @brief AutoNumberingDockWidget::setActive
+ * Set current used autonumberings
+ */
+void AutoNumberingDockWidget::setActive() {
+
+	if (projectview_!=NULL) {
+	//Conductor
+	QString conductor_autonum = projectview_->currentDiagram()->diagram()->conductorsAutonumName();
+	int conductor_index = ui->m_conductor_cb->findText(conductor_autonum);
+	ui->m_conductor_cb->setCurrentIndex(conductor_index);
+
+	//Element
+	QString element_formula = project_->elementAutoNumFormula();
+	QString active_element_autonum = project_->elementAutoNum_2().key(element_formula);
+	int el_index = ui->m_element_cb->findText(active_element_autonum);
+	ui->m_element_cb->setCurrentIndex(el_index);
+
+	//Folio
+	QString page_autonum = project_->defaultTitleBlockProperties().auto_page_num;
+	int folio_index = ui->m_folio_cb->findText(page_autonum);
+	ui->m_folio_cb->setCurrentIndex(folio_index);
+	}
+}
+
+/**
+ * @brief AutoNumberingDockWidget::conductorAutoNumChanged
+ * Add new or remove conductor auto num from combobox
+ */
+void AutoNumberingDockWidget::conductorAutoNumChanged() {
+
+	ui->m_conductor_cb->clear();
+
+	//Conductor Combobox
+	QList <QString> keys_conductor = project_->conductorAutoNum().keys();
+	if (!keys_conductor.isEmpty()) {
+		foreach (QString str, keys_conductor) { ui->m_conductor_cb-> addItem(str); }
+	}
+	setActive();
+}
+
+/**
+ * @brief AutoNumberingDockWidget::on_m_conductor_cb_activated
+ * @param unused
+ * Set new conductor AutoNum
+ */
+void AutoNumberingDockWidget::on_m_conductor_cb_activated(int) {
+	QString current_autonum = ui->m_conductor_cb->currentText();
+	projectview_->currentDiagram()->diagram()->setConductorsAutonumName(current_autonum);
+}
+
+/**
+ * @brief AutoNumberingDockWidget::elementAutoNumChanged
+ * Add new or remove element auto num from combobox
+ */
+void AutoNumberingDockWidget::elementAutoNumChanged() {
+
+	ui->m_element_cb->clear();
+
+	//Element Combobox
+	QList <QString> keys_element = project_->elementAutoNum().keys();
+	if (!keys_element.isEmpty()) {
+		foreach (QString str, keys_element) {ui->m_element_cb -> addItem(str);}
+	}
+	setActive();
+}
+
+/**
+ * @brief AutoNumberingDockWidget::on_m_element_cb_activated
+ * @param unused
+ * Set new element AutoNum
+ */
+void AutoNumberingDockWidget::on_m_element_cb_activated(int) {
+	QString current_autonum = ui->m_element_cb->currentText();
+	QString current_formula = project_->elementAutoNumFormula(current_autonum);
+	if (current_formula!=NULL)
+		project_->setElementAutoNumCurrentFormula(current_formula);
+}
+
+/**
+ * @brief AutoNumberingDockWidget::folioAutoNumChanged
+ * Add new or remove folio auto num from combobox
+ */
+void AutoNumberingDockWidget::folioAutoNumChanged() {
+
+	ui->m_folio_cb->clear();
+
+	//Folio Combobox
+	QList <QString> keys_folio = project_->folioAutoNum().keys();
+	if (!keys_folio.isEmpty()) {
+		foreach (QString str, keys_folio) { ui->m_folio_cb -> addItem(str);}
+	}
+	setActive();
+}
+
+/**
+ * @brief AutoNumberingDockWidget::on_m_folio_cb_activated
+ * @param unused
+ * Set new folio AutoNum
+ */
+void AutoNumberingDockWidget::on_m_folio_cb_activated(int) {
+	QString current_autonum = ui->m_folio_cb->currentText();
+	TitleBlockProperties ip = project_->defaultTitleBlockProperties();
+	ip.setAutoPageNum(current_autonum);
+	project_->setDefaultTitleBlockProperties(ip);
+	emit(folioAutoNumChanged(current_autonum));
+}

Added: trunk/sources/ui/autonumberingdockwidget.h
===================================================================
--- trunk/sources/ui/autonumberingdockwidget.h	                        (rev 0)
+++ trunk/sources/ui/autonumberingdockwidget.h	2016-07-13 14:57:27 UTC (rev 4573)
@@ -0,0 +1,63 @@
+/*
+	Copyright 2006-2016 The QElectroTech Team
+	This file is part of QElectroTech.
+
+	QElectroTech 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 2 of the License, or
+	(at your option) any later version.
+
+	QElectroTech 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 QElectroTech.  If not, see <http://www.gnu.org/licenses/>.
+*/
+#ifndef AUTONUMBERINGDOCKWIDGET_H
+#define AUTONUMBERINGDOCKWIDGET_H_H
+
+#include "qetproject.h"
+#include "projectview.h"
+#include <QDockWidget>
+
+namespace Ui {
+	class AutoNumberingDockWidget;
+}
+
+class AutoNumberingDockWidget : public QDockWidget
+{
+		Q_OBJECT
+
+	public:
+		explicit AutoNumberingDockWidget(QWidget *parent = 0, QETProject *project = nullptr);
+		~AutoNumberingDockWidget();
+
+		void setContext();
+		void setProject(QETProject*, ProjectView*);
+
+	public slots:
+		void setActive();
+		void setConductorActive(DiagramView*);
+
+	private slots:
+		void on_m_conductor_cb_activated(int);
+		void on_m_element_cb_activated(int);
+		void on_m_folio_cb_activated(int);
+		void conductorAutoNumChanged();
+		void elementAutoNumChanged();
+		void folioAutoNumChanged();
+		void clear();
+
+	signals:
+		void folioAutoNumChanged(QString);
+
+	private:
+		Ui::AutoNumberingDockWidget *ui;
+		QETProject* project_;
+		ProjectView* projectview_;
+
+};
+
+#endif // AUTONUMBERINGDOCKWIDGET_H

Added: trunk/sources/ui/autonumberingdockwidget.ui
===================================================================
--- trunk/sources/ui/autonumberingdockwidget.ui	                        (rev 0)
+++ trunk/sources/ui/autonumberingdockwidget.ui	2016-07-13 14:57:27 UTC (rev 4573)
@@ -0,0 +1,94 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<ui version="4.0">
+ <class>AutoNumberingDockWidget</class>
+ <widget class="QDockWidget" name="AutoNumberingDockWidget">
+  <property name="geometry">
+   <rect>
+    <x>0</x>
+    <y>0</y>
+    <width>400</width>
+    <height>300</height>
+   </rect>
+  </property>
+  <property name="windowTitle">
+   <string>Autonumerotation Séléction</string>
+  </property>
+  <widget class="QWidget" name="dockWidgetContents">
+   <layout class="QVBoxLayout" name="verticalLayout">
+    <property name="sizeConstraint">
+     <enum>QLayout::SetMaximumSize</enum>
+    </property>
+    <property name="leftMargin">
+     <number>0</number>
+    </property>
+    <property name="topMargin">
+     <number>0</number>
+    </property>
+    <property name="rightMargin">
+     <number>0</number>
+    </property>
+    <property name="bottomMargin">
+     <number>0</number>
+    </property>
+    <item>
+     <widget class="QGroupBox" name="groupBox">
+      <property name="title">
+       <string/>
+      </property>
+      <layout class="QVBoxLayout" name="verticalLayout_2">
+       <item>
+        <layout class="QGridLayout" name="gridLayout">
+         <item row="1" column="0">
+          <widget class="QLabel" name="label">
+           <property name="text">
+            <string>Element</string>
+           </property>
+          </widget>
+         </item>
+         <item row="1" column="1">
+          <widget class="QComboBox" name="m_element_cb"/>
+         </item>
+         <item row="0" column="1">
+          <widget class="QComboBox" name="m_conductor_cb"/>
+         </item>
+         <item row="0" column="0">
+          <widget class="QLabel" name="label_2">
+           <property name="text">
+            <string>Conductor</string>
+           </property>
+          </widget>
+         </item>
+         <item row="2" column="0">
+          <widget class="QLabel" name="label_3">
+           <property name="text">
+            <string>Folio</string>
+           </property>
+          </widget>
+         </item>
+         <item row="3" column="0">
+          <spacer name="verticalSpacer">
+           <property name="orientation">
+            <enum>Qt::Vertical</enum>
+           </property>
+           <property name="sizeHint" stdset="0">
+            <size>
+             <width>20</width>
+             <height>40</height>
+            </size>
+           </property>
+          </spacer>
+         </item>
+         <item row="2" column="1">
+          <widget class="QComboBox" name="m_folio_cb"/>
+         </item>
+        </layout>
+       </item>
+      </layout>
+     </widget>
+    </item>
+   </layout>
+  </widget>
+ </widget>
+ <resources/>
+ <connections/>
+</ui>

Modified: trunk/sources/ui/diagrampropertiesdialog.cpp
===================================================================
--- trunk/sources/ui/diagrampropertiesdialog.cpp	2016-07-13 04:57:02 UTC (rev 4572)
+++ trunk/sources/ui/diagrampropertiesdialog.cpp	2016-07-13 14:57:27 UTC (rev 4573)
@@ -110,6 +110,7 @@
 		// Conductor autonum name
 		if (m_asw -> text() != diagram -> conductorsAutonumName()) {
 			diagram -> setConductorsAutonumName (m_asw -> text());
+			diagram->project()->conductorAutoNumChanged();
 		}
 	}
 }


Mail converted by MHonArc 2.6.19+ http://listengine.tuxfamily.org/