mirror of
https://github.com/qelectrotech/qelectrotech-source-mirror.git
synced 2025-12-17 20:50:34 +01:00
Compare commits
2 Commits
feature_re
...
sqldatabas
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f6bef3a365 | ||
|
|
b69dea1747 |
5
.gitignore
vendored
5
.gitignore
vendored
@@ -1,7 +1,2 @@
|
||||
*.snap
|
||||
.flatpak-builder
|
||||
# Qt build output
|
||||
*.user
|
||||
# doxygen Doxyfile output
|
||||
doc/
|
||||
QElectroTech.tag
|
||||
|
||||
@@ -27,7 +27,6 @@
|
||||
#include <QtCore/QSharedMemory>
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 10, 0) // ### Qt 6: remove
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.10 or later")
|
||||
#include <QRandomGenerator>
|
||||
#endif
|
||||
#include "singleapplication.h"
|
||||
@@ -107,7 +106,6 @@ SingleApplication::SingleApplication( int &argc, char *argv[], bool allowSeconda
|
||||
qsrand( QDateTime::currentMSecsSinceEpoch() % std::numeric_limits<uint>::max() );
|
||||
QThread::sleep( 8 + static_cast <unsigned long>( static_cast <float>( qrand() ) / RAND_MAX * 10 ) );
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.10 or later")
|
||||
quint32 value = QRandomGenerator::global()->generate();
|
||||
QThread::sleep( 8 + static_cast <unsigned long>( static_cast <float>( value ) / RAND_MAX * 10 ) );
|
||||
#endif
|
||||
|
||||
@@ -3,7 +3,5 @@
|
||||
<name lang="fr">11- Schémas et plans d'installation, architecturaux et topographiques</name>
|
||||
<name lang="es">11- Dibujos y planos arquitectónicos y topográficos</name>
|
||||
<name lang="da">11- Bygningsmæssige og topografiske installationstegninger og -skemaer</name>
|
||||
<name lang="en">11- Installation, architectural and topographical diagrams and plans</name>
|
||||
<name lang="be">11- Installatie, bouwkundig en topografische schema's en plannen</name>
|
||||
</names>
|
||||
</qet-directory>
|
||||
|
||||
@@ -641,7 +641,6 @@ void ElementsCollectionWidget::search()
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
QStringList text_list = text.split("+", QString::SkipEmptyParts);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
QStringList text_list = text.split("+", Qt::SkipEmptyParts);
|
||||
#endif
|
||||
QModelIndexList match_index;
|
||||
|
||||
@@ -754,7 +754,6 @@ QDebug operator<< (QDebug debug, const ElementsLocation &location)
|
||||
QDebugStateSaver saver(debug);
|
||||
|
||||
#if QT_VERSION >= 0x050400
|
||||
#pragma message("@TODO remove code for QT 5.04 or later")
|
||||
debug.noquote();
|
||||
#else
|
||||
debug.nospace();
|
||||
|
||||
@@ -27,7 +27,7 @@
|
||||
- 17 columns of 60.0 px wide by 20.0px high
|
||||
- 8 lines of 80.0 px high by 20.0px wide
|
||||
|
||||
\~French Initialise un objet BorderProperties avec les proprietes par
|
||||
Initialise un objet BorderProperties avec les proprietes par
|
||||
defaut suivantes :
|
||||
- 17 colonnes affichees de 60.0 px de large pour 20.0px de haut
|
||||
- 8 lignes affichees de 80.0 px de haut pour 20.0px de large
|
||||
@@ -53,11 +53,12 @@ BorderProperties::~BorderProperties() {
|
||||
|
||||
/**
|
||||
@brief BorderProperties::operator ==
|
||||
|
||||
\~ @param bp : Other BorderProperties container/class.
|
||||
\~French Autre conteneur BorderProperties
|
||||
\~ @return True if it and this container are identical, false otherwise.
|
||||
\~French True si ip et ce conteneur sont identiques, false sinon
|
||||
@param bp :
|
||||
- other BorderProperties container/class
|
||||
- autre conteneur BorderProperties
|
||||
@return
|
||||
- true if it and this container are identical, false otherwise
|
||||
- true si ip et ce conteneur sont identiques, false sinon
|
||||
*/
|
||||
bool BorderProperties::operator==(const BorderProperties &bp) {
|
||||
return(
|
||||
@@ -74,13 +75,12 @@ bool BorderProperties::operator==(const BorderProperties &bp) {
|
||||
|
||||
/**
|
||||
@brief BorderProperties::operator !=
|
||||
|
||||
\~ @param bp :
|
||||
Other BorderProperties container/class.
|
||||
\~French Autre conteneur BorderProperties
|
||||
\~ @return
|
||||
False if it and this container are identical, true otherwise.
|
||||
\~French False si bp et ce conteneur sont identiques, true sinon
|
||||
@param bp :
|
||||
- other BorderProperties container/class
|
||||
- autre conteneur BorderProperties
|
||||
@return
|
||||
- false if it and this container are identical, true otherwise
|
||||
- false si bp et ce conteneur sont identiques, true sinon
|
||||
*/
|
||||
bool BorderProperties::operator!=(const BorderProperties &bp) {
|
||||
return(!(*this == bp));
|
||||
@@ -88,12 +88,11 @@ bool BorderProperties::operator!=(const BorderProperties &bp) {
|
||||
|
||||
/**
|
||||
@brief BorderProperties::toXml
|
||||
Exports dimensions as XML attributes added to element e.
|
||||
\~French Exporte les dimensions sous formes d'attributs XML ajoutes a l'element e.
|
||||
|
||||
\~ @param e :
|
||||
XML element to which attributes will be added
|
||||
\~French Element XML auquel seront ajoutes des attributs
|
||||
- Exports dimensions as XML attributes added to element e.
|
||||
- Exporte les dimensions sous formes d'attributs XML ajoutes a l'element e.
|
||||
@param e :
|
||||
- XML element to which attributes will be added
|
||||
- Element XML auquel seront ajoutes des attributs
|
||||
*/
|
||||
void BorderProperties::toXml(QDomElement &e) const {
|
||||
e.setAttribute("cols", columns_count);
|
||||
@@ -106,12 +105,11 @@ void BorderProperties::toXml(QDomElement &e) const {
|
||||
|
||||
/**
|
||||
@brief BorderProperties::fromXml
|
||||
Import dimensions from XML attributes of element e
|
||||
\~French Importe les dimensions a partir des attributs XML de l'element e
|
||||
|
||||
\~ @param e :
|
||||
XML element whose attributes will be read
|
||||
\~French Element XML dont les attributs seront lus
|
||||
- Import dimensions from XML attributes of element e
|
||||
- Importe les dimensions a partir des attributs XML de l'element e
|
||||
@param e :
|
||||
- XML element whose attributes will be read
|
||||
- Element XML dont les attributs seront lus
|
||||
*/
|
||||
void BorderProperties::fromXml(QDomElement &e) {
|
||||
if (e.hasAttribute("cols")) columns_count = e.attribute("cols").toInt();
|
||||
@@ -124,15 +122,14 @@ void BorderProperties::fromXml(QDomElement &e) {
|
||||
|
||||
/**
|
||||
@brief BorderProperties::toSettings
|
||||
Export dimensions in a QSettings object.
|
||||
\~French Exporte les dimensions dans une configuration.
|
||||
|
||||
\~ @param settings :
|
||||
QSettings object to write
|
||||
\~French Parametres a ecrire
|
||||
\~ @param prefix :
|
||||
prefix to be added before the names of the parameters
|
||||
\~French prefixe a ajouter devant les noms des parametres
|
||||
- Export dimensions in a QSettings object.
|
||||
- Exporte les dimensions dans une configuration.
|
||||
@param settings :
|
||||
- QSettings object to write
|
||||
- Parametres a ecrire
|
||||
@param prefix :
|
||||
- prefix to be added before the names of the parameters
|
||||
- prefixe a ajouter devant les noms des parametres
|
||||
*/
|
||||
void BorderProperties::toSettings(QSettings &settings, const QString &prefix) const {
|
||||
settings.setValue(prefix + "cols", columns_count);
|
||||
@@ -145,12 +142,14 @@ void BorderProperties::toSettings(QSettings &settings, const QString &prefix) co
|
||||
|
||||
/**
|
||||
@brief BorderProperties::fromSettings
|
||||
Import dimensions from a QSettings object.
|
||||
\~French Importe les dimensions depuis une configuration.
|
||||
\~ @param settings : QSettings object to read
|
||||
\~French Parametres a lire
|
||||
\~ @param prefix : prefix to be added before the names of the parameters
|
||||
\~French prefixe a ajouter devant les noms des parametres
|
||||
- Import dimensions from a QSettings object.
|
||||
- Importe les dimensions depuis une configuration.
|
||||
@param settings :
|
||||
- QSettings object to read
|
||||
- Parametres a lire
|
||||
@param prefix :
|
||||
- prefix to be added before the names of the parameters
|
||||
- prefixe a ajouter devant les noms des parametres
|
||||
*/
|
||||
void BorderProperties::fromSettings(QSettings &settings, const QString &prefix) {
|
||||
columns_count = settings.value(prefix + "cols", columns_count).toInt();
|
||||
|
||||
File diff suppressed because it is too large
Load Diff
@@ -29,7 +29,6 @@ class DiagramPosition;
|
||||
class TitleBlockTemplate;
|
||||
class TitleBlockTemplateRenderer;
|
||||
/**
|
||||
@brief The BorderTitleBlock class
|
||||
This class represents the border and the titleblock which frame a
|
||||
particular electric diagram.
|
||||
*/
|
||||
@@ -51,43 +50,30 @@ class BorderTitleBlock : public QObject
|
||||
|
||||
//METHODS TO GET DIMENSION
|
||||
//COLUMNS
|
||||
/// @return the number of columns
|
||||
/// @return the number of columns
|
||||
int columnsCount() const { return(columns_count_); }
|
||||
/// @return the columns width, in pixels
|
||||
/// @return the columns width, in pixels
|
||||
qreal columnsWidth() const { return(columns_width_); }
|
||||
/// @return the total width of all columns, headers excluded
|
||||
qreal columnsTotalWidth() const {
|
||||
return(columns_count_ * columns_width_); }
|
||||
/// @return the column headers height, in pixels
|
||||
qreal columnsHeaderHeight() const {
|
||||
return(columns_header_height_); }
|
||||
/// @return the total width of all columns, headers excluded
|
||||
qreal columnsTotalWidth() const { return(columns_count_ * columns_width_); }
|
||||
/// @return the column headers height, in pixels
|
||||
qreal columnsHeaderHeight() const { return(columns_header_height_); }
|
||||
|
||||
//ROWS
|
||||
/// @return the number of rows
|
||||
/// @return the number of rows
|
||||
int rowsCount() const { return(rows_count_); }
|
||||
/// @return the rows height, in pixels
|
||||
/// @return the rows height, in pixels
|
||||
qreal rowsHeight() const { return(rows_height_); }
|
||||
/// @return the total height of all rows, headers excluded
|
||||
qreal rowsTotalHeight() const {
|
||||
return(rows_count_ * rows_height_); }
|
||||
/// @return la rows header width, in pixels
|
||||
/// @return the total height of all rows, headers excluded
|
||||
qreal rowsTotalHeight() const { return(rows_count_ * rows_height_); }
|
||||
/// @return la rows header width, in pixels
|
||||
qreal rowsHeaderWidth() const { return(rows_header_width_); }
|
||||
|
||||
// border - title block = diagram
|
||||
/**
|
||||
@brief diagramWidth
|
||||
@return the diagram width,
|
||||
i.e. the width of the border without title block
|
||||
*/
|
||||
qreal diagramWidth() const {
|
||||
return(columnsTotalWidth() + rowsHeaderWidth()); }
|
||||
/**
|
||||
@brief diagramHeight
|
||||
@return the diagram height,
|
||||
i.e. the height of the border without title block
|
||||
*/
|
||||
qreal diagramHeight() const {
|
||||
return(rowsTotalHeight() + columnsHeaderHeight()); }
|
||||
/// @return the diagram width, i.e. the width of the border without title block
|
||||
qreal diagramWidth() const { return(columnsTotalWidth() + rowsHeaderWidth()); }
|
||||
/// @return the diagram height, i.e. the height of the border without title block
|
||||
qreal diagramHeight() const { return(rowsTotalHeight() + columnsHeaderHeight()); }
|
||||
|
||||
QRectF titleBlockRect () const;
|
||||
|
||||
@@ -102,49 +88,45 @@ class BorderTitleBlock : public QObject
|
||||
QRectF outsideBorderRect() const;
|
||||
QRectF insideBorderRect() const;
|
||||
|
||||
// methods to get title block basic data
|
||||
/// @return the value of the title block "Author" field
|
||||
// methods to get title block basic data
|
||||
/// @return the value of the title block "Author" field
|
||||
QString author() const { return(btb_author_); }
|
||||
/// @return the value of the title block "Date" field
|
||||
/// @return the value of the title block "Date" field
|
||||
QDate date() const { return(btb_date_); }
|
||||
/// @return the value of the title block "Title" field
|
||||
/// @return the value of the title block "Title" field
|
||||
QString title() const { return(btb_title_); }
|
||||
/// @return the value of the title block "Folio" field
|
||||
/// @return the value of the title block "Folio" field
|
||||
QString folio() const { return(btb_folio_); }
|
||||
/// @return the value of the title block "Folio" field as displayed
|
||||
/// @return the value of the title block "Folio" field as displayed
|
||||
QString finalfolio() const { return(btb_final_folio_); }
|
||||
/// @return the value of the title block "Plant" field
|
||||
/// @return the value of the title block "Plant" field
|
||||
QString plant() const { return(btb_plant_); }
|
||||
/// @return the value of the title block "Locmach" field
|
||||
/// @return the value of the title block "Locmach" field
|
||||
QString locmach() const { return(btb_locmach_); }
|
||||
/// @return the value of the revision index block "Folio" field
|
||||
/// @return the value of the revision index block "Folio" field
|
||||
QString indexrev() const { return(btb_indexrev_); }
|
||||
/// @return the value of the title block "File" field
|
||||
/// @return the value of the title block "File" field
|
||||
QString fileName() const { return(btb_filename_); }
|
||||
/// @return the value of the title block Additional Fields
|
||||
/// @return the value of the title block Additional Fields
|
||||
QString version() const { return(btb_version_); }
|
||||
/// @return the value of the title block Additional Fields
|
||||
DiagramContext additionalFields() const {
|
||||
return (additional_fields_); }
|
||||
/// @return the value of the title block
|
||||
/// @return the value of the title block Additional Fields
|
||||
DiagramContext additionalFields() const { return (additional_fields_); }
|
||||
/// @return the value of the title block
|
||||
QString autoPageNum() const { return(btb_auto_page_num_); }
|
||||
/// @return the value of the total number of folios
|
||||
/// @return the value of the total number of folios
|
||||
int folioTotal() const { return(folio_total_);}
|
||||
|
||||
// methods to get display options
|
||||
/// @return true si le cartouche est affiche, false sinon
|
||||
bool titleBlockIsDisplayed() const {
|
||||
return(display_titleblock_); }
|
||||
/// @return true si les entetes des colonnes sont affiches,
|
||||
/// false sinon
|
||||
// methods to get display options
|
||||
/// @return true si le cartouche est affiche, false sinon
|
||||
bool titleBlockIsDisplayed() const { return(display_titleblock_); }
|
||||
/// @return true si les entetes des colonnes sont affiches, false sinon
|
||||
bool columnsAreDisplayed() const { return(display_columns_); }
|
||||
/// @return true si les entetes des lignes sont affiches,
|
||||
/// false sinon
|
||||
/// @return true si les entetes des lignes sont affiches, false sinon
|
||||
bool rowsAreDisplayed() const { return(display_rows_); }
|
||||
/// @return true si la bordure est affichee, false sinon
|
||||
/// @return true si la bordure est affichee, false sinon
|
||||
bool borderIsDisplayed() const { return(display_border_); }
|
||||
|
||||
// methods to set dimensions
|
||||
// methods to set dimensions
|
||||
void setColumnsCount(int);
|
||||
void setRowsCount(int);
|
||||
void setColumnsWidth(const qreal &);
|
||||
@@ -155,13 +137,12 @@ class BorderTitleBlock : public QObject
|
||||
|
||||
DiagramPosition convertPosition(const QPointF &);
|
||||
|
||||
// methods to set title block basic data
|
||||
// methods to set title block basic data
|
||||
void setAuthor(const QString &author);
|
||||
void setDate(const QDate &date);
|
||||
void setTitle(const QString &title);
|
||||
void setFolio(const QString &folio);
|
||||
void setFolioData(int, int, const QString& = nullptr,
|
||||
const DiagramContext & = DiagramContext());
|
||||
void setFolioData(int, int, const QString& = nullptr, const DiagramContext & = DiagramContext());
|
||||
void setPlant(const QString &plant);
|
||||
void setLocMach(const QString &locmach);
|
||||
void setIndicerev(const QString &indexrev);
|
||||
@@ -187,11 +168,9 @@ class BorderTitleBlock : public QObject
|
||||
|
||||
public slots:
|
||||
void titleBlockTemplateChanged(const QString &);
|
||||
void titleBlockTemplateRemoved(
|
||||
const QString &,
|
||||
const TitleBlockTemplate * = nullptr);
|
||||
void titleBlockTemplateRemoved(const QString &, const TitleBlockTemplate * = nullptr);
|
||||
|
||||
// methods to set display options
|
||||
// methods to set display options
|
||||
void displayTitleBlock(bool);
|
||||
void displayColumns(bool);
|
||||
void displayRows(bool);
|
||||
@@ -200,86 +179,77 @@ class BorderTitleBlock : public QObject
|
||||
|
||||
private:
|
||||
void updateRectangles();
|
||||
void updateDiagramContextForTitleBlock(
|
||||
const DiagramContext & = DiagramContext());
|
||||
void updateDiagramContextForTitleBlock(const DiagramContext & = DiagramContext());
|
||||
QString incrementLetters(const QString &);
|
||||
|
||||
signals:
|
||||
/**
|
||||
@brief borderChanged
|
||||
Signal emitted after the border has changed
|
||||
@param old_border Former border
|
||||
@param new_border New border
|
||||
*/
|
||||
/**
|
||||
Signal emitted after the border has changed
|
||||
@param old_border Former border
|
||||
@param new_border New border
|
||||
*/
|
||||
void borderChanged(QRectF old_border, QRectF new_border);
|
||||
/**
|
||||
@brief displayChanged
|
||||
Signal emitted after display options have changed
|
||||
*/
|
||||
/**
|
||||
Signal emitted after display options have changed
|
||||
*/
|
||||
void displayChanged();
|
||||
/**
|
||||
@brief diagramTitleChanged
|
||||
Signal emitted after the title has changed
|
||||
*/
|
||||
/**
|
||||
Signal emitted after the title has changed
|
||||
*/
|
||||
void diagramTitleChanged(const QString &);
|
||||
/**
|
||||
@brief titleBlockFolioChanged
|
||||
Signal emitted after Folio has changed
|
||||
*/
|
||||
/**
|
||||
@brief titleBlockFolioChanged
|
||||
Signal emitted after Folio has changed
|
||||
*/
|
||||
void titleBlockFolioChanged(const QString &);
|
||||
/**
|
||||
@brief needFolioData
|
||||
Signal emitted when the title block
|
||||
requires its data to be updated
|
||||
in order to generate the folio field.
|
||||
*/
|
||||
/**
|
||||
Signal emitted when the title block requires its data to be updated in order
|
||||
to generate the folio field.
|
||||
*/
|
||||
void needFolioData();
|
||||
/**
|
||||
@brief needTitleBlockTemplate
|
||||
Signal emitted when this object needs to
|
||||
set a specific title block template.
|
||||
This object cannot handle the job
|
||||
since it does not know of its parent project.
|
||||
*/
|
||||
/**
|
||||
Signal emitted when this object needs to set a specific title block
|
||||
template. This object cannot handle the job since it does not know of
|
||||
its parent project.
|
||||
*/
|
||||
void needTitleBlockTemplate(const QString &);
|
||||
|
||||
// attributes
|
||||
// attributes
|
||||
private:
|
||||
// titleblock basic data
|
||||
QString btb_author_; ///< titleblock author
|
||||
QDate btb_date_; ///< titleblock date
|
||||
QString btb_title_; ///< titleblock title
|
||||
QString btb_folio_; ///< titleblock folio
|
||||
QString btb_plant_; ///< titleblock plant
|
||||
QString btb_locmach_; ///< titleblock locmach
|
||||
QString btb_indexrev_; ///< titleblock index rev
|
||||
QString btb_final_folio_; ///< titleblock final folio
|
||||
QString btb_auto_page_num_; ///< titleblock auto page num
|
||||
int folio_index_; ///< titleblock index
|
||||
int folio_total_; ///< titleblock total
|
||||
QString btb_filename_; ///< titleblock filename
|
||||
QString btb_version_; ///< titleblock version
|
||||
/// titleblock additional fields
|
||||
// titleblock basic data
|
||||
QString btb_author_;
|
||||
QDate btb_date_;
|
||||
QString btb_title_;
|
||||
QString btb_folio_;
|
||||
QString btb_plant_;
|
||||
QString btb_locmach_;
|
||||
QString btb_indexrev_;
|
||||
QString btb_final_folio_;
|
||||
QString btb_auto_page_num_;
|
||||
int folio_index_;
|
||||
int folio_total_;
|
||||
QString btb_filename_;
|
||||
QString btb_version_;
|
||||
DiagramContext additional_fields_;
|
||||
Qt::Edge m_edge; ///< titleblock edge
|
||||
QString m_next_folio_num; ///< titleblock next folio num
|
||||
QString m_previous_folio_num; ///< titleblock previous folio num
|
||||
Qt::Edge m_edge;
|
||||
QString m_next_folio_num,
|
||||
m_previous_folio_num;
|
||||
|
||||
// border dimensions (rows and columns)
|
||||
// columns: number and dimensions
|
||||
int columns_count_; ///< columns count
|
||||
qreal columns_width_; ///< columns width
|
||||
qreal columns_header_height_; ///< columns header height
|
||||
// border dimensions (rows and columns)
|
||||
// columns: number and dimensions
|
||||
int columns_count_;
|
||||
qreal columns_width_;
|
||||
qreal columns_header_height_;
|
||||
|
||||
// rows: number and dimensions
|
||||
int rows_count_; ///< rows count
|
||||
qreal rows_height_; ///< rows height
|
||||
qreal rows_header_width_; ///< rows header width
|
||||
// rows: number and dimensions
|
||||
int rows_count_;
|
||||
qreal rows_height_;
|
||||
qreal rows_header_width_;
|
||||
|
||||
// title block dimensions
|
||||
// title block dimensions
|
||||
qreal titleblock_height_;
|
||||
|
||||
// rectangles used for drawing operations
|
||||
// rectangles used for drawing operations
|
||||
QRectF diagram_rect_;
|
||||
|
||||
// display options
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
Copyright 2006-2020 The QElectroTech team
|
||||
Copyright 2006-2014 The QElectroTech team
|
||||
This file is part of QElectroTech.
|
||||
|
||||
QElectroTech is free software: you can redistribute it and/or modify
|
||||
@@ -26,23 +26,16 @@
|
||||
#include "assignvariables.h"
|
||||
|
||||
/**
|
||||
@brief ConductorAutoNumerotation::ConductorAutoNumerotation
|
||||
Constructor of autonum, after create a class,
|
||||
call numerate to apply the autonum.
|
||||
When autonum is applyed,
|
||||
they do with an undo command added to the stack of diagram.
|
||||
If you give a parent_undo at constructor,
|
||||
the undo command create in this class have parent_undo for parent,
|
||||
and wasn't added to the stack of diagram
|
||||
(it's the responsabillty of the parent_undo)
|
||||
@param conductor : the conductor to apply automatic numerotation
|
||||
@param diagram : the diagram of conductor
|
||||
@param parent_undo : parent undo command
|
||||
*/
|
||||
ConductorAutoNumerotation::ConductorAutoNumerotation(
|
||||
Conductor *conductor,
|
||||
Diagram *diagram,
|
||||
QUndoCommand *parent_undo) :
|
||||
* @brief ConductorAutoNumerotation::ConductorAutoNumerotation
|
||||
* Constructor of autonum, after create a class, call numerate to apply the autonum.
|
||||
* When autonum is applyed, they do with an undo command added to the stack of diagram.
|
||||
* If you give a parent_undo at constructor, the undo command create in this class have parent_undo for parent,
|
||||
* and wasn't added to the stack of diagram (it's the responsabillty of the parent_undo)
|
||||
* @param conductor : the conductor to apply automatic numerotation
|
||||
* @param diagram : the diagram of conductor
|
||||
* @param parent_undo : parent undo command
|
||||
*/
|
||||
ConductorAutoNumerotation::ConductorAutoNumerotation(Conductor *conductor, Diagram *diagram, QUndoCommand *parent_undo) :
|
||||
m_diagram (diagram),
|
||||
m_conductor (conductor),
|
||||
conductor_list (conductor -> relatedPotentialConductors().values()),
|
||||
@@ -50,22 +43,19 @@ ConductorAutoNumerotation::ConductorAutoNumerotation(
|
||||
{}
|
||||
|
||||
/**
|
||||
@brief ConductorAutoNumerotation::numerate
|
||||
execute the automatic numerotation
|
||||
*/
|
||||
* @brief ConductorAutoNumerotation::numerate
|
||||
* execute the automatic numerotation
|
||||
*/
|
||||
void ConductorAutoNumerotation::numerate() {
|
||||
if (!m_conductor) return;
|
||||
if (conductor_list.size() >= 1 ) numeratePotential();
|
||||
else if (m_conductor -> properties().type == ConductorProperties::Multi)
|
||||
numerateNewConductor();
|
||||
else if (m_conductor -> properties().type == ConductorProperties::Multi) numerateNewConductor();
|
||||
}
|
||||
|
||||
/**
|
||||
@brief ConductorAutoNumerotation::applyText
|
||||
apply the text @t to @conductor_
|
||||
and all conductors at the same potential
|
||||
@param t : Conductor text
|
||||
*/
|
||||
* @brief ConductorAutoNumerotation::applyText
|
||||
* apply the text @t to @conductor_ and all conductors at the same potential
|
||||
*/
|
||||
void ConductorAutoNumerotation::applyText(const QString& t)
|
||||
{
|
||||
if (!m_conductor) return;
|
||||
@@ -80,36 +70,20 @@ void ConductorAutoNumerotation::applyText(const QString& t)
|
||||
|
||||
if (m_parent_undo)
|
||||
{
|
||||
new QPropertyUndoCommand(
|
||||
m_conductor,
|
||||
"properties",
|
||||
old_value,
|
||||
new_value,
|
||||
m_parent_undo);
|
||||
new QPropertyUndoCommand(m_conductor, "properties", old_value, new_value, m_parent_undo);
|
||||
undo = m_parent_undo;
|
||||
}
|
||||
else
|
||||
{
|
||||
undo = new QUndoCommand();
|
||||
new QPropertyUndoCommand(
|
||||
m_conductor,
|
||||
"properties",
|
||||
old_value,
|
||||
new_value,
|
||||
undo);
|
||||
undo->setText(
|
||||
QObject::tr(
|
||||
"Modifier les propriétés d'un conducteur",
|
||||
"undo caption"));
|
||||
new QPropertyUndoCommand(m_conductor, "properties", old_value, new_value, undo);
|
||||
undo->setText(QObject::tr("Modifier les propriétés d'un conducteur", "undo caption"));
|
||||
}
|
||||
|
||||
if (!conductor_list.isEmpty())
|
||||
{
|
||||
if (!m_parent_undo)
|
||||
undo->setText(
|
||||
QObject::tr(
|
||||
"Modifier les propriétés de plusieurs conducteurs",
|
||||
"undo caption"));
|
||||
undo->setText(QObject::tr("Modifier les propriétés de plusieurs conducteurs", "undo caption"));
|
||||
|
||||
foreach (Conductor *cond, conductor_list)
|
||||
{
|
||||
@@ -117,12 +91,7 @@ void ConductorAutoNumerotation::applyText(const QString& t)
|
||||
old_value.setValue(cp2);
|
||||
cp2.text = t;
|
||||
new_value.setValue(cp2);
|
||||
new QPropertyUndoCommand(
|
||||
cond,
|
||||
"properties",
|
||||
old_value,
|
||||
new_value,
|
||||
undo);
|
||||
new QPropertyUndoCommand(cond, "properties", old_value, new_value, undo);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -131,19 +100,15 @@ void ConductorAutoNumerotation::applyText(const QString& t)
|
||||
}
|
||||
|
||||
/**
|
||||
@brief ConductorAutoNumerotation::newProperties
|
||||
Create a new properties according to the current autonum rule of diagram
|
||||
@param diagram : Diagram class
|
||||
@param cp : ConductorProperties
|
||||
@param seq : sequentialNumbers
|
||||
*/
|
||||
void ConductorAutoNumerotation::newProperties(
|
||||
Diagram *diagram,
|
||||
ConductorProperties &cp,
|
||||
autonum::sequentialNumbers &seq)
|
||||
* @brief ConductorAutoNumerotation::newProperties
|
||||
* Create a new properties according to the current autonum rule of diagram
|
||||
* @param d
|
||||
* @param cp
|
||||
* @param seq
|
||||
*/
|
||||
void ConductorAutoNumerotation::newProperties(Diagram *diagram, ConductorProperties &cp, autonum::sequentialNumbers &seq)
|
||||
{
|
||||
NumerotationContext context = diagram->project()->conductorAutoNum(
|
||||
diagram->conductorsAutonumName());
|
||||
NumerotationContext context = diagram->project()->conductorAutoNum(diagram->conductorsAutonumName());
|
||||
if (context.isEmpty()) {
|
||||
return;
|
||||
}
|
||||
@@ -159,9 +124,9 @@ void ConductorAutoNumerotation::newProperties(
|
||||
}
|
||||
|
||||
/**
|
||||
@brief ConductorAutoNumerotation::numeratePotential
|
||||
Numerate a conductor on an existing potential
|
||||
*/
|
||||
* @brief ConductorAutoNumerotation::numeratePotential
|
||||
* Numerate a conductor on an existing potential
|
||||
*/
|
||||
void ConductorAutoNumerotation::numeratePotential()
|
||||
{
|
||||
ConductorProperties cp = conductor_list.first()->properties();
|
||||
@@ -171,8 +136,7 @@ void ConductorAutoNumerotation::numeratePotential()
|
||||
if (conductor->properties() != cp)
|
||||
properties_equal = false;
|
||||
}
|
||||
// Every properties of the potential is equal,
|
||||
// so we apply it to m_conductor
|
||||
//Every properties of the potential is equal, so we apply it to m_conductor
|
||||
if (properties_equal)
|
||||
{
|
||||
m_conductor->setProperties(cp);
|
||||
@@ -205,25 +169,21 @@ void ConductorAutoNumerotation::numeratePotential()
|
||||
//the texts isn't identicals
|
||||
else
|
||||
{
|
||||
PotentialSelectorDialog psd(
|
||||
m_conductor,
|
||||
m_parent_undo,
|
||||
m_conductor->diagramEditor());
|
||||
PotentialSelectorDialog psd(m_conductor, m_parent_undo, m_conductor->diagramEditor());
|
||||
psd.exec();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@brief ConductorAutoNumerotation::numerateNewConductor
|
||||
create and apply a new numerotation to @m_conductor
|
||||
*/
|
||||
* @brief ConductorAutoNumerotation::numerateNewConductor
|
||||
* create and apply a new numerotation to @m_conductor
|
||||
*/
|
||||
void ConductorAutoNumerotation::numerateNewConductor()
|
||||
{
|
||||
if (!m_conductor || m_diagram->conductorsAutonumName().isEmpty())
|
||||
return;
|
||||
|
||||
NumerotationContext context = m_diagram->project()->conductorAutoNum(
|
||||
m_diagram -> conductorsAutonumName());
|
||||
NumerotationContext context = m_diagram->project()->conductorAutoNum(m_diagram -> conductorsAutonumName());
|
||||
if (context.isEmpty())
|
||||
return;
|
||||
|
||||
@@ -234,17 +194,10 @@ void ConductorAutoNumerotation::numerateNewConductor()
|
||||
cp.m_formula = formula;
|
||||
m_conductor->setProperties(cp);
|
||||
|
||||
autonum::setSequential(formula,
|
||||
m_conductor->rSequenceNum(),
|
||||
context,
|
||||
m_diagram,
|
||||
autoNum_name);
|
||||
autonum::setSequential(formula, m_conductor->rSequenceNum(), context, m_diagram, autoNum_name);
|
||||
|
||||
NumerotationContextCommands ncc (context, m_diagram);
|
||||
m_diagram->project()->addConductorAutoNum(autoNum_name, ncc.next());
|
||||
|
||||
applyText(autonum::AssignVariables::formulaToLabel(
|
||||
formula,
|
||||
m_conductor->rSequenceNum(),
|
||||
m_diagram));
|
||||
applyText(autonum::AssignVariables::formulaToLabel(formula, m_conductor->rSequenceNum(), m_diagram));
|
||||
}
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
/*
|
||||
Copyright 2006-2020 The QElectroTech team
|
||||
Copyright 2006-2014 The QElectroTech team
|
||||
This file is part of QElectroTech.
|
||||
|
||||
QElectroTech is free software: you can redistribute it and/or modify
|
||||
@@ -26,26 +26,19 @@ class Conductor;
|
||||
class QUndoCommand;
|
||||
class ConductorProperties;
|
||||
|
||||
/**
|
||||
@brief The ConductorAutoNumerotation class
|
||||
*/
|
||||
class ConductorAutoNumerotation
|
||||
{
|
||||
public:
|
||||
//constructors & destructor
|
||||
ConductorAutoNumerotation (Conductor *conductor,
|
||||
Diagram *diagram,
|
||||
QUndoCommand *undo_parent = nullptr);
|
||||
ConductorAutoNumerotation (Conductor *conductor, Diagram *diagram, QUndoCommand *undo_parent = nullptr);
|
||||
|
||||
//methods
|
||||
//methods
|
||||
void numerate ();
|
||||
void applyText (const QString&);
|
||||
static void newProperties(Diagram *diagram,
|
||||
ConductorProperties &cp,
|
||||
autonum::sequentialNumbers &seq);
|
||||
static void newProperties(Diagram *diagram, ConductorProperties &cp, autonum::sequentialNumbers &seq);
|
||||
|
||||
private:
|
||||
//methods
|
||||
//methods
|
||||
void numeratePotential ();
|
||||
void numerateNewConductor ();
|
||||
|
||||
|
||||
@@ -70,7 +70,6 @@ bool ConductorNumExport::toCsv()
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 15, 0) // ### Qt 6: remove
|
||||
stream << wiresNum() << endl;
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.15 or later")
|
||||
stream << wiresNum() << &Qt::endl(stream);
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -331,23 +331,12 @@ void ConductorProperties::fromXml(QDomElement &e)
|
||||
horiz_rotate_text = e.attribute("horizrotatetext").toDouble();
|
||||
|
||||
QMetaEnum me = QMetaEnum::fromType<Qt::Alignment>();
|
||||
m_horizontal_alignment = Qt::Alignment(
|
||||
me.keyToValue(
|
||||
e.attribute(
|
||||
"horizontal-alignment",
|
||||
"AlignBottom"
|
||||
).toStdString().data()));
|
||||
m_vertical_alignment = Qt::Alignment(
|
||||
me.keyToValue(
|
||||
e.attribute(
|
||||
"vertical-alignment",
|
||||
"AlignRight"
|
||||
).toStdString().data()));
|
||||
m_horizontal_alignment = Qt::Alignment(me.keyToValue(e.attribute("horizontal-alignment", "AlignBottom").toStdString().data()));
|
||||
m_vertical_alignment = Qt::Alignment(me.keyToValue(e.attribute("vertical-alignment", "AlignRight").toStdString().data()));
|
||||
|
||||
//Keep retrocompatible with version older than 0,4
|
||||
//If the propertie @type is simple (removed since QET 0,4), we set text no visible.
|
||||
//@TODO remove this code for qet 0.6 or later
|
||||
#pragma message("@TODO remove this code for qet 0.6 or later")
|
||||
//Keep retrocompatible with version older than 0,4
|
||||
//If the propertie @type is simple (removed since QET 0,4), we set text no visible.
|
||||
//@TODO remove this code for qet 0.6 or later
|
||||
if (e.attribute("type") == "simple") m_show_text = false;
|
||||
}
|
||||
|
||||
@@ -765,7 +754,6 @@ void ConductorProperties::readStyle(const QString &style_string) {
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
QStringList styles = style_string.split(";", QString::SkipEmptyParts);
|
||||
#else
|
||||
#pragma message("@TODO remove code QString::SkipEmptyParts for QT 5.14 or later")
|
||||
QStringList styles = style_string.split(";", Qt::SkipEmptyParts);
|
||||
#endif
|
||||
|
||||
|
||||
@@ -25,7 +25,6 @@
|
||||
class QPainter;
|
||||
|
||||
/**
|
||||
@brief The SingleLineProperties class
|
||||
This class represents the properties of a singleline conductor.
|
||||
*/
|
||||
class SingleLineProperties {
|
||||
@@ -60,7 +59,6 @@ class SingleLineProperties {
|
||||
};
|
||||
|
||||
/**
|
||||
@brief The ConductorProperties class
|
||||
This class represents the functional properties of a particular conductor,
|
||||
i.e. properties other than path and terminals.
|
||||
*/
|
||||
@@ -71,15 +69,14 @@ class ConductorProperties
|
||||
virtual ~ConductorProperties();
|
||||
|
||||
/**
|
||||
@brief The ConductorType enum Represents
|
||||
the kind of a particular conductor:
|
||||
Single: singleline symbols, no text input
|
||||
Multi: text input, no symbol
|
||||
*/
|
||||
* @brief The ConductorType enum Represents the kind of a particular conductor:
|
||||
* Single: singleline symbols, no text input
|
||||
* Multi: text input, no symbol
|
||||
*/
|
||||
enum ConductorType { Single, Multi };
|
||||
|
||||
|
||||
//Attributes
|
||||
//Attributes
|
||||
ConductorType type;
|
||||
|
||||
QColor color,
|
||||
@@ -111,7 +108,7 @@ class ConductorProperties
|
||||
|
||||
SingleLineProperties singleLineProperties;
|
||||
|
||||
// methods
|
||||
// methods
|
||||
void toXml(QDomElement &) const;
|
||||
void fromXml(QDomElement &);
|
||||
void toSettings(QSettings &, const QString & = QString()) const;
|
||||
@@ -121,7 +118,7 @@ class ConductorProperties
|
||||
|
||||
static ConductorProperties defaultProperties();
|
||||
|
||||
// operators
|
||||
// operators
|
||||
bool operator==(const ConductorProperties &) const;
|
||||
bool operator!=(const ConductorProperties &) const;
|
||||
|
||||
|
||||
@@ -15,74 +15,46 @@
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with QElectroTech. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
#include <QScrollArea>
|
||||
#include "configdialog.h"
|
||||
#include "configpages.h"
|
||||
#include "qetapp.h"
|
||||
|
||||
#include "machine_info.h"
|
||||
|
||||
/**
|
||||
Constructeur
|
||||
@param parent QWidget parent
|
||||
*/
|
||||
ConfigDialog::ConfigDialog(QWidget *parent) : QDialog(parent) {
|
||||
Machine_info *mymachineinfo= new Machine_info(this);
|
||||
//ScrollArea for low screens
|
||||
QScrollArea *scroll = new QScrollArea(this);
|
||||
scroll->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
|
||||
scroll->setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);
|
||||
|
||||
// liste des pages
|
||||
pages_list = new QListWidget();
|
||||
pages_list -> setViewMode(QListView::IconMode);
|
||||
if(mymachineinfo->get_max_screen_height()<1000){
|
||||
pages_list -> setIconSize(QSize(64, 64));
|
||||
} else {
|
||||
pages_list -> setIconSize(QSize(128, 128));
|
||||
}
|
||||
pages_list -> setIconSize(QSize(128, 128));
|
||||
pages_list -> setMovement(QListView::Static);
|
||||
pages_list -> setMinimumWidth(168);
|
||||
pages_list -> setMaximumWidth(168);
|
||||
pages_list -> setSpacing(16);
|
||||
pages_list -> setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
|
||||
|
||||
pages_list -> setMinimumWidth(168);
|
||||
pages_list -> setMaximumWidth(168);
|
||||
pages_list -> setSpacing(16);
|
||||
pages_list -> setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
|
||||
|
||||
// pages
|
||||
pages_widget = new QStackedWidget();
|
||||
|
||||
// boutons
|
||||
buttons = new QDialogButtonBox(
|
||||
QDialogButtonBox::Ok
|
||||
|QDialogButtonBox::Cancel);
|
||||
|
||||
|
||||
QWidget *viewport = new QWidget(this);
|
||||
scroll->setWidget(viewport);
|
||||
scroll->setWidgetResizable(true);
|
||||
|
||||
buttons = new QDialogButtonBox(QDialogButtonBox::Ok|QDialogButtonBox::Cancel);
|
||||
|
||||
// layouts
|
||||
QHBoxLayout *hlayout1 = new QHBoxLayout(viewport);
|
||||
// add needed widgets to layout "hlayout1"
|
||||
QHBoxLayout *hlayout1 = new QHBoxLayout();
|
||||
hlayout1 -> addWidget(pages_list);
|
||||
hlayout1 -> addWidget(pages_widget);
|
||||
|
||||
//add hlayout1 to widget
|
||||
viewport->setLayout(hlayout1);
|
||||
|
||||
// Add a layout for QDialog
|
||||
QVBoxLayout *dialog_layout = new QVBoxLayout(this);
|
||||
dialog_layout->addWidget(scroll); // add scroll to the QDialog's layout
|
||||
dialog_layout -> addWidget(buttons);
|
||||
setLayout(dialog_layout);
|
||||
|
||||
|
||||
QVBoxLayout *vlayout1 = new QVBoxLayout();
|
||||
vlayout1 -> addLayout(hlayout1);
|
||||
vlayout1 -> addWidget(buttons);
|
||||
setLayout(vlayout1);
|
||||
|
||||
// connexion signaux / slots
|
||||
connect(buttons, SIGNAL(accepted()), this, SLOT(applyConf()));
|
||||
connect(buttons, SIGNAL(rejected()), this, SLOT(reject()));
|
||||
connect(pages_list, SIGNAL(currentRowChanged(int)),
|
||||
pages_widget, SLOT(setCurrentIndex(int)));
|
||||
|
||||
resize(mymachineinfo->get_max_screen_width(),
|
||||
mymachineinfo->get_max_screen_height());
|
||||
|
||||
connect(pages_list, SIGNAL(currentRowChanged(int)), pages_widget, SLOT(setCurrentIndex(int)));
|
||||
|
||||
#ifdef Q_OS_MACOS
|
||||
if (parent) {
|
||||
setWindowFlags(Qt::Sheet);
|
||||
|
||||
@@ -46,7 +46,6 @@ ElementQueryWidget::ElementQueryWidget(QWidget *parent) :
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 15, 0) // ### Qt 6: remove
|
||||
connect(&m_button_group, static_cast<void (QButtonGroup::*)(int)>(&QButtonGroup::buttonClicked), [this](int id)
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.15 or later")
|
||||
connect(&m_button_group, static_cast<void (QButtonGroup::*)(int)>(&QButtonGroup::idClicked), [this](int id)
|
||||
#endif
|
||||
{
|
||||
|
||||
@@ -927,6 +927,8 @@ bool Diagram::fromXml(QDomElement &document, QPointF position, bool consider_inf
|
||||
const QDomElement& root = document;
|
||||
// The first element must be a diagram
|
||||
if (root.tagName() != "diagram") return(false);
|
||||
|
||||
qDebug() << "Diagram: " << root.attribute("title");
|
||||
|
||||
// Read attributes of this diagram
|
||||
if (consider_informations) {
|
||||
@@ -1023,6 +1025,7 @@ bool Diagram::fromXml(QDomElement &document, QPointF position, bool consider_inf
|
||||
}
|
||||
|
||||
int state = 0;
|
||||
qDebug() << "Element from collection: " << element_location;
|
||||
Element *nvel_elmt = ElementFactory::Instance() -> createElement(element_location, nullptr, &state);
|
||||
if (state)
|
||||
{
|
||||
@@ -1141,7 +1144,6 @@ bool Diagram::fromXml(QDomElement &document, QPointF position, bool consider_inf
|
||||
content_ptr -> m_images = added_images.toSet();
|
||||
content_ptr -> m_shapes = added_shapes.toSet();
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
content_ptr -> m_text_fields = QSet<IndependentTextItem *>(
|
||||
added_texts.begin(),
|
||||
added_texts.end());
|
||||
|
||||
@@ -118,7 +118,7 @@ int DiagramContext::count() {
|
||||
|
||||
/**
|
||||
* @brief DiagramContext::keyMustShow
|
||||
* @return the value pairs with key, if key no found, return false
|
||||
* @return the value pairs with key, if key not found, return false
|
||||
*/
|
||||
bool DiagramContext::keyMustShow(const QString &key) const {
|
||||
if (m_content_show.contains(key))
|
||||
|
||||
@@ -416,7 +416,6 @@ void ChangeZValueCommand::applyRaise(const QList<QGraphicsItem *> &items_list) {
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 13, 0) // ### Qt 6: remove
|
||||
my_items_list.swap(i, i + 1);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.13 or later")
|
||||
my_items_list.swapItemsAt(i, i + 1);
|
||||
#endif
|
||||
}
|
||||
@@ -439,7 +438,6 @@ void ChangeZValueCommand::applyLower(const QList<QGraphicsItem *> &items_list) {
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 13, 0) // ### Qt 6: remove
|
||||
my_items_list.swap(i, i - 1);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.13 or later")
|
||||
my_items_list.swapItemsAt(i, i - 1);
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -498,7 +498,6 @@ void CustomElementGraphicPart::stylesFromXml(const QDomElement &qde)
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
QStringList styles = qde.attribute("style").split(";", QString::SkipEmptyParts);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
QStringList styles = qde.attribute("style").split(";", Qt::SkipEmptyParts);
|
||||
#endif
|
||||
|
||||
|
||||
@@ -51,9 +51,8 @@ ElementsCollectionCache::ElementsCollectionCache(const QString &database_path, Q
|
||||
cache_db_.exec("PRAGMA locking_mode = EXCLUSIVE");
|
||||
cache_db_.exec("PRAGMA synchronous = OFF");
|
||||
|
||||
//TODO This code remove old table with mtime for create table with uuid, created at version 0,5
|
||||
//see to remove this code at version 0,6 or 0,7 when all users will table with uuid.
|
||||
#pragma message("@TODO remove this code for qet 0.6 or later")
|
||||
//TODO This code remove old table with mtime for create table with uuid, created at version 0,5
|
||||
//see to remove this code at version 0,6 or 0,7 when all users will table with uuid.
|
||||
QSqlQuery table_name(cache_db_);
|
||||
if (table_name.exec("PRAGMA table_info(names)"))
|
||||
{
|
||||
|
||||
@@ -559,7 +559,6 @@ void ElementPictureFactory::setPainterStyle(const QDomElement &dom, QPainter &pa
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
const QStringList styles = dom.attribute("style").split(";", QString::SkipEmptyParts);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
const QStringList styles = dom.attribute("style").split(";", Qt::SkipEmptyParts);
|
||||
#endif
|
||||
QRegExp rx("^\\s*([a-z-]+)\\s*:\\s*([a-zA-Z-]+)\\s*$");
|
||||
|
||||
@@ -1,85 +0,0 @@
|
||||
/*
|
||||
Copyright 2006-2020 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 "machine_info.h"
|
||||
#include <QScreen>
|
||||
#include <QApplication>
|
||||
|
||||
/**
|
||||
@brief Machine_info::Machine_info
|
||||
@param parent
|
||||
*/
|
||||
Machine_info::Machine_info(QObject *parent) : QObject(parent)
|
||||
{
|
||||
init_get_Screen_info();
|
||||
}
|
||||
|
||||
/**
|
||||
@brief Machine_info::init_get_Screen_info
|
||||
Finds the largest screen and saves the values
|
||||
*/
|
||||
void Machine_info::init_get_Screen_info()
|
||||
{
|
||||
const auto screens = qApp->screens();
|
||||
for (int ii = 0; ii < screens.count(); ++ii)
|
||||
{
|
||||
if(
|
||||
Max_screen_width
|
||||
<
|
||||
screens[ii]->geometry().width()
|
||||
*
|
||||
screens[ii]->devicePixelRatio()
|
||||
)
|
||||
{
|
||||
Max_screen_width =
|
||||
screens[ii]->geometry().width()
|
||||
*
|
||||
screens[ii]->devicePixelRatio();
|
||||
}
|
||||
if(
|
||||
Max_screen_height
|
||||
<
|
||||
screens[ii]->geometry().height()
|
||||
*
|
||||
screens[ii]->devicePixelRatio()
|
||||
)
|
||||
{
|
||||
Max_screen_height =
|
||||
screens[ii]->geometry().height()
|
||||
*
|
||||
screens[ii]->devicePixelRatio();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@brief Machine_info::get_max_screen_width
|
||||
@return max screen width
|
||||
*/
|
||||
int32_t Machine_info::get_max_screen_width()
|
||||
{
|
||||
return Max_screen_width;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief Machine_info::get_max_screen_height
|
||||
@return max screen height
|
||||
*/
|
||||
int32_t Machine_info::get_max_screen_height()
|
||||
{
|
||||
return Max_screen_height;
|
||||
}
|
||||
@@ -1,45 +0,0 @@
|
||||
/*
|
||||
Copyright 2006-2020 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 MACHINE_INFO_H
|
||||
#define MACHINE_INFO_H
|
||||
|
||||
#include <QObject>
|
||||
|
||||
/**
|
||||
@brief The Machine_info class
|
||||
This class hold information from your PC.
|
||||
*/
|
||||
class Machine_info : public QObject
|
||||
{
|
||||
Q_OBJECT
|
||||
public:
|
||||
explicit Machine_info(QObject *parent = nullptr);
|
||||
int32_t get_max_screen_width();
|
||||
int32_t get_max_screen_height();
|
||||
|
||||
signals:
|
||||
|
||||
private:
|
||||
void init_get_Screen_info();
|
||||
int32_t Max_screen_width;
|
||||
int32_t Max_screen_height;
|
||||
|
||||
|
||||
};
|
||||
|
||||
#endif // MACHINE_INFO_H
|
||||
@@ -22,32 +22,29 @@
|
||||
#include <QStyleFactory>
|
||||
|
||||
/**
|
||||
@brief main
|
||||
Main function of QElectroTech
|
||||
@param argc : number of parameters
|
||||
\~French number of paramètres
|
||||
\~ @param argv : parameters
|
||||
\~French paramètres
|
||||
\~ @return exit code
|
||||
*/
|
||||
* @brief main
|
||||
* Main function of QElectroTech
|
||||
* @param argc : number of paramètres
|
||||
* @param argv : paramètres
|
||||
* @return
|
||||
*/
|
||||
int main(int argc, char **argv)
|
||||
{
|
||||
//Some setup, notably to use with QSetting.
|
||||
//Some setup, notably to use with QSetting.
|
||||
QCoreApplication::setOrganizationName("QElectroTech");
|
||||
QCoreApplication::setOrganizationDomain("qelectrotech.org");
|
||||
QCoreApplication::setApplicationName("QElectroTech");
|
||||
//Creation and execution of the application
|
||||
//HighDPI
|
||||
//Creation and execution of the application
|
||||
//HighDPI
|
||||
#if QT_VERSION >= QT_VERSION_CHECK(5, 6, 0)
|
||||
#pragma message("@TODO remove code for QT 5.6 or later")
|
||||
QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
|
||||
QCoreApplication::setAttribute(Qt::AA_EnableHighDpiScaling);
|
||||
#else
|
||||
qputenv("QT_DEVICE_PIXEL_RATIO", QByteArray("auto"));
|
||||
qputenv("QT_DEVICE_PIXEL_RATIO", QByteArray("auto"));
|
||||
#endif
|
||||
SingleApplication app(argc, argv, true);
|
||||
#ifdef Q_OS_MACOS
|
||||
//Handle the opening of QET when user double click on a .qet .elmt .tbt file
|
||||
//or drop these same files to the QET icon of the dock
|
||||
//Handle the opening of QET when user double click on a .qet .elmt .tbt file
|
||||
//or drop these same files to the QET icon of the dock
|
||||
MacOSXOpenEvent open_event;
|
||||
app.installEventFilter(&open_event);
|
||||
app.setStyle(QStyleFactory::create("Fusion"));
|
||||
@@ -56,19 +53,17 @@ int main(int argc, char **argv)
|
||||
if (app.isSecondary())
|
||||
{
|
||||
QStringList arg_list = app.arguments();
|
||||
//Remove the first argument, it's the binary file
|
||||
//Remove the first argument, it's the binary file
|
||||
arg_list.takeFirst();
|
||||
QETArguments qetarg(arg_list);
|
||||
QString message = "launched-with-args: " + QET::joinWithSpaces(
|
||||
QStringList(qetarg.arguments()));
|
||||
QString message = "launched-with-args: " + QET::joinWithSpaces(QStringList(qetarg.arguments()));
|
||||
app.sendMessage(message.toUtf8());
|
||||
return 0;
|
||||
}
|
||||
|
||||
QETApp qetapp;
|
||||
QETApp::instance()->installEventFilter(&qetapp);
|
||||
QObject::connect(&app, &SingleApplication::receivedMessage,
|
||||
&qetapp, &QETApp::receiveMessage);
|
||||
QObject::connect(&app, &SingleApplication::receivedMessage, &qetapp, &QETApp::receiveMessage);
|
||||
|
||||
return app.exec();
|
||||
}
|
||||
|
||||
@@ -69,7 +69,6 @@ bool nomenclature::saveToCSVFile()
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 15, 0) // ### Qt 6: remove
|
||||
stream << getNomenclature() << endl;
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.15 or later")
|
||||
stream << getNomenclature() << &Qt::endl(stream);
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -17,16 +17,6 @@
|
||||
*/
|
||||
#include "propertiesinterface.h"
|
||||
|
||||
/**
|
||||
@brief PropertiesInterface::PropertiesInterface
|
||||
*/
|
||||
PropertiesInterface::PropertiesInterface()
|
||||
{
|
||||
}
|
||||
/**
|
||||
@brief PropertiesInterface::~PropertiesInterface
|
||||
*/
|
||||
PropertiesInterface::~PropertiesInterface()
|
||||
{
|
||||
|
||||
}
|
||||
|
||||
@@ -23,45 +23,19 @@
|
||||
#include <QDomElement>
|
||||
|
||||
/**
|
||||
@brief The PropertiesInterface class
|
||||
This class is an interface for have common way
|
||||
to use properties in QElectroTech
|
||||
*/
|
||||
* @brief The PropertiesInterface class
|
||||
* This class is an interface for have common way to use properties in QElectroTech
|
||||
*/
|
||||
class PropertiesInterface
|
||||
{
|
||||
public:
|
||||
PropertiesInterface();
|
||||
virtual ~PropertiesInterface();
|
||||
/**
|
||||
@brief toSettings
|
||||
Save properties to setting file.
|
||||
@param settings : is use for prefix a word
|
||||
befor the name of each paramètre
|
||||
*/
|
||||
virtual void toSettings (QSettings &settings,
|
||||
const QString = QString()) const =0;
|
||||
/**
|
||||
@brief fromSettings
|
||||
load properties to setting file.
|
||||
@param settings : is use for prefix a word
|
||||
befor the name of each paramètre
|
||||
*/
|
||||
virtual void fromSettings (const QSettings &settings,
|
||||
const QString = QString()) =0;
|
||||
/**
|
||||
@brief toXml
|
||||
Save properties to xml element
|
||||
@param xml_document
|
||||
@return QDomElement
|
||||
*/
|
||||
virtual QDomElement toXml (QDomDocument &xml_document) const =0;
|
||||
/**
|
||||
@brief fromXml
|
||||
load properties to xml element
|
||||
@param xml_element
|
||||
@return true / false
|
||||
*/
|
||||
virtual bool fromXml (const QDomElement &xml_element) =0;
|
||||
PropertiesInterface();
|
||||
// Save/load properties to setting file. QString is use for prefix a word befor the name of each paramètre
|
||||
virtual void toSettings (QSettings &settings, const QString = QString()) const =0;
|
||||
virtual void fromSettings (const QSettings &settings, const QString = QString()) =0;
|
||||
// Save/load properties to xml element
|
||||
virtual QDomElement toXml (QDomDocument &xml_document) const =0;
|
||||
virtual bool fromXml (const QDomElement &xml_element) =0;
|
||||
};
|
||||
|
||||
#endif // PROPERTIESINTERFACE_H
|
||||
|
||||
@@ -20,9 +20,6 @@
|
||||
|
||||
#include <QString>
|
||||
|
||||
/**
|
||||
@brief The ReportProperties class
|
||||
*/
|
||||
class ReportProperties
|
||||
{
|
||||
public:
|
||||
|
||||
@@ -3,16 +3,16 @@
|
||||
#include <QGraphicsObject>
|
||||
|
||||
TerminalData::TerminalData():
|
||||
PropertiesInterface()
|
||||
PropertiesInterface()
|
||||
{
|
||||
init();
|
||||
init();
|
||||
}
|
||||
|
||||
TerminalData::TerminalData(QGraphicsObject *parent):
|
||||
PropertiesInterface(),
|
||||
q(parent)
|
||||
PropertiesInterface(),
|
||||
q(parent)
|
||||
{
|
||||
init();
|
||||
init();
|
||||
}
|
||||
|
||||
void TerminalData::init() {
|
||||
@@ -23,114 +23,65 @@ TerminalData::~TerminalData()
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
@brief TerminalData::setParent
|
||||
@param parent
|
||||
*/
|
||||
void TerminalData::setParent(QGraphicsObject* parent)
|
||||
{
|
||||
q = parent;
|
||||
q = parent;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief TerminalData::toSettings
|
||||
Save properties to setting file.
|
||||
|
||||
QString is use for prefix a word befor the name of each paramètre
|
||||
@param settings UNUSED
|
||||
*/
|
||||
void TerminalData::toSettings(QSettings &settings, const QString) const
|
||||
|
||||
{
|
||||
Q_UNUSED(settings);
|
||||
}
|
||||
|
||||
/**
|
||||
@brief TerminalData::fromSettings
|
||||
load properties to setting file.
|
||||
|
||||
QString is use for prefix a word befor the name of each paramètre
|
||||
@param settings UNUSED
|
||||
*/
|
||||
void TerminalData::fromSettings(const QSettings &settings, const QString)
|
||||
{
|
||||
Q_UNUSED(settings);
|
||||
}
|
||||
|
||||
/**
|
||||
@brief TerminalData::toXml
|
||||
Save properties to xml element
|
||||
write the name, number, position and orientation of the terminal
|
||||
to xml_element
|
||||
|
||||
@note This method is only called from the PartTerminal
|
||||
and should never called from the Terminal class
|
||||
@param xml_document
|
||||
@return xml_element : DomElement with
|
||||
the name, number, position and orientation of the terminal
|
||||
*/
|
||||
QDomElement TerminalData::toXml(QDomDocument &xml_document) const
|
||||
{
|
||||
QDomElement xml_element = xml_document.createElement("terminal");
|
||||
QDomElement xml_element = xml_document.createElement("terminal");
|
||||
|
||||
// write the position of the terminal
|
||||
// ecrit la position de la borne
|
||||
xml_element.setAttribute("x", QString("%1").arg(q->scenePos().x()));
|
||||
xml_element.setAttribute("y", QString("%1").arg(q->scenePos().y()));
|
||||
// ecrit la position de la borne
|
||||
xml_element.setAttribute("x", QString("%1").arg(q->scenePos().x()));
|
||||
xml_element.setAttribute("y", QString("%1").arg(q->scenePos().y()));
|
||||
|
||||
// Write name and number to XML
|
||||
xml_element.setAttribute("uuid", m_uuid.toString());
|
||||
xml_element.setAttribute("name", m_name);
|
||||
|
||||
// write the orientation of the terminal
|
||||
// ecrit l'orientation de la borne
|
||||
xml_element.setAttribute("orientation",
|
||||
Qet::orientationToString(m_orientation));
|
||||
xml_element.setAttribute("uuid", m_uuid.toString());
|
||||
xml_element.setAttribute("name", m_name);
|
||||
|
||||
return(xml_element);
|
||||
// ecrit l'orientation de la borne
|
||||
xml_element.setAttribute("orientation", Qet::orientationToString(m_orientation));
|
||||
// Write name and number to XML
|
||||
|
||||
return(xml_element);
|
||||
}
|
||||
|
||||
/**
|
||||
@brief TerminalData::fromXml
|
||||
load properties to xml element
|
||||
|
||||
@note This method is only called from the PartTerminal
|
||||
and should never called from the Terminal class
|
||||
@param xml_element
|
||||
@return true if succeeded / false if the attribute is not real
|
||||
*/
|
||||
bool TerminalData::fromXml (const QDomElement &xml_element)
|
||||
{
|
||||
qreal term_x = 0.0;
|
||||
qreal term_y = 0.0;
|
||||
// lit la position de la borne
|
||||
qreal term_x = 0.0, term_y = 0.0;
|
||||
if (!QET::attributeIsAReal(xml_element, "x", &term_x))
|
||||
return false;
|
||||
|
||||
// reads the position of the terminal
|
||||
// lit la position de la borne
|
||||
if (!QET::attributeIsAReal(xml_element, "x", &term_x))
|
||||
return false;
|
||||
if (!QET::attributeIsAReal(xml_element, "y", &term_y))
|
||||
return false;
|
||||
|
||||
if (!QET::attributeIsAReal(xml_element, "y", &term_y))
|
||||
return false;
|
||||
m_pos = QPointF(term_x, term_y);
|
||||
|
||||
m_pos = QPointF(term_x, term_y);
|
||||
//emit posFromXML(QPointF(term_x, term_y));
|
||||
|
||||
//emit posFromXML(QPointF(term_x, term_y));
|
||||
QString uuid = xml_element.attribute("uuid");
|
||||
// update part and add uuid, which is used in the new version to connect terminals together
|
||||
// if the attribute not exists, means, the element is created with an older version of qet. So use the legacy approach
|
||||
// to identify terminals
|
||||
if (!uuid.isEmpty())
|
||||
m_uuid = QUuid(uuid);
|
||||
|
||||
QString uuid = xml_element.attribute("uuid");
|
||||
// update part and add uuid, which is used in the new version
|
||||
// to connect terminals together
|
||||
// if the attribute not exists, means, the element is created with an
|
||||
// older version of qet. So use the legacy approach
|
||||
// to identify terminals
|
||||
if (!uuid.isEmpty())
|
||||
m_uuid = QUuid(uuid);
|
||||
m_name = xml_element.attribute("name");
|
||||
|
||||
m_name = xml_element.attribute("name");
|
||||
// lit l'orientation de la borne
|
||||
m_orientation = Qet::orientationFromString(xml_element.attribute("orientation"));
|
||||
|
||||
// read the orientation of the terminal
|
||||
// lit l'orientation de la borne
|
||||
m_orientation = Qet::orientationFromString(
|
||||
xml_element.attribute("orientation"));
|
||||
|
||||
return true;
|
||||
return true;
|
||||
}
|
||||
|
||||
@@ -18,70 +18,62 @@ class QGraphicsObject;
|
||||
*/
|
||||
class TerminalData : public PropertiesInterface
|
||||
{
|
||||
public:
|
||||
TerminalData();
|
||||
TerminalData(QGraphicsObject* parent);
|
||||
~TerminalData();
|
||||
public:
|
||||
TerminalData();
|
||||
TerminalData(QGraphicsObject* parent);
|
||||
~TerminalData();
|
||||
|
||||
void init();
|
||||
void init();
|
||||
|
||||
void setParent(QGraphicsObject* parent);
|
||||
void toSettings(QSettings &settings,
|
||||
const QString = QString()) const override;
|
||||
void fromSettings(const QSettings &settings,
|
||||
const QString = QString()) override;
|
||||
QDomElement toXml(QDomDocument &xml_element) const override;
|
||||
bool fromXml(const QDomElement &xml_element) override;
|
||||
void setParent(QGraphicsObject* parent);
|
||||
|
||||
// must be public, because this class is a private member
|
||||
// of PartTerminal/Terminal and they must access this data
|
||||
public:
|
||||
/**
|
||||
@brief m_orientation
|
||||
Orientation of the terminal
|
||||
*/
|
||||
Qet::Orientation m_orientation;
|
||||
/**
|
||||
@brief second_point
|
||||
Position of the second point of the terminal
|
||||
in scene coordinates
|
||||
*/
|
||||
QPointF second_point;
|
||||
/**
|
||||
@brief m_uuid
|
||||
Uuid of the terminal.
|
||||
// Save/load properties to setting file. QString is use for prefix a word befor the name of each paramètre
|
||||
void toSettings(QSettings &settings, const QString = QString()) const override;
|
||||
void fromSettings(const QSettings &settings, const QString = QString()) override;
|
||||
// Save/load properties to xml element
|
||||
// This method is only called from the PartTerminal and should never called from the Terminal class
|
||||
QDomElement toXml(QDomDocument &xml_element) const override;
|
||||
bool fromXml(const QDomElement &xml_element) override;
|
||||
|
||||
In elementscene.cpp an element gets a new uuid when
|
||||
saving the element. In the current state
|
||||
each connection is made by using the local position
|
||||
of the terminal and a dynamic id. In the new
|
||||
case, each terminal should have it's own uuid to
|
||||
identify it uniquely. When changing each time this
|
||||
uuid, the conductor after updating the part is anymore
|
||||
valid. So if in the loaded document a uuid exists,
|
||||
use this one and don't create a new one.
|
||||
*/
|
||||
QUuid m_uuid;
|
||||
/**
|
||||
@brief m_name
|
||||
Name of the element.
|
||||
It can be used to create wiring harness tables
|
||||
*/
|
||||
QString m_name;
|
||||
// must be public, because this class is a private member of PartTerminal/Terminal and they must
|
||||
// access this data
|
||||
public:
|
||||
/*!
|
||||
* \brief m_orientation
|
||||
* Orientation of the terminal
|
||||
*/
|
||||
Qet::Orientation m_orientation;
|
||||
/*!
|
||||
* \brief second_point
|
||||
* Position of the second point of the terminal in scene coordinates
|
||||
*/
|
||||
QPointF second_point;
|
||||
/*!
|
||||
* \brief m_uuid
|
||||
* Uuid of the terminal.
|
||||
*
|
||||
* In elementscene.cpp an element gets a new uuid when saving the element. In the current state
|
||||
* each connection is made by using the local position of the terminal and a dynamic id. In the new
|
||||
* case, each terminal should have it's own uuid to identify it uniquely. When changing each time this
|
||||
* uuid, the conductor after updating the part is anymore valid. So if in the loaded document a uuid exists,
|
||||
* use this one and don't create a new one.
|
||||
*/
|
||||
QUuid m_uuid;
|
||||
/*!
|
||||
* \brief m_name
|
||||
* Name of the element. It can be used to create wiring harness tables
|
||||
*/
|
||||
QString m_name;
|
||||
|
||||
/**
|
||||
@brief m_pos
|
||||
Position of the terminal. The second point is calculated
|
||||
from this position and the orientation
|
||||
@note
|
||||
Important: this variable is only updated during read
|
||||
from xml and not during mouse move!
|
||||
It is used to store the initial position so that
|
||||
PartTerminal and Terminal have access to it.
|
||||
*/
|
||||
QPointF m_pos;
|
||||
private:
|
||||
QGraphicsObject* q{nullptr};
|
||||
/*!
|
||||
* \brief m_pos
|
||||
* Position of the terminal. The second point is calculated from this position and the orientation
|
||||
* Important: this variable is only updated during read from xml and not during mouse move!
|
||||
* It is used to store the initial position so that PartTerminal and Terminal have access to it.
|
||||
*/
|
||||
QPointF m_pos;
|
||||
private:
|
||||
QGraphicsObject* q{nullptr};
|
||||
};
|
||||
|
||||
#endif // TERMINALDATA_H
|
||||
|
||||
@@ -176,7 +176,6 @@ bool QET::orthogonalProjection(const QPointF &point, const QLineF &line, QPointF
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0)
|
||||
QLineF::IntersectType it = line.intersect(perpendicular_line, &intersection_point); // ### Qt 6: remove
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
QLineF::IntersectType it = line.intersects(perpendicular_line, &intersection_point);
|
||||
#endif
|
||||
|
||||
@@ -451,7 +450,6 @@ QStringList QET::splitWithSpaces(const QString &string) {
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
QStringList escaped_strings = string.split(QRegExp("[^\\]?(?:\\\\)* "), QString::SkipEmptyParts);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
QStringList escaped_strings = string.split(QRegExp("[^\\]?(?:\\\\)* "), Qt::SkipEmptyParts);
|
||||
#endif
|
||||
|
||||
|
||||
@@ -2220,19 +2220,19 @@ void QETDiagramEditor::generateTerminalBlock()
|
||||
success = process->startDetached("qet_tb_generator", {(QETDiagramEditor::currentProjectView()->project()->filePath())});
|
||||
}
|
||||
else {
|
||||
success = process->startDetached("qet_tb_generator", {("")});
|
||||
success = process->startDetached("qet_tb_generator");
|
||||
}
|
||||
if (openedProjects().count()){
|
||||
success = process->startDetached(QDir::homePath() + "/Application Data/qet/qet_tb_generator.exe", {(QETDiagramEditor::currentProjectView()->project()->filePath())});
|
||||
}
|
||||
else {
|
||||
success = process->startDetached(QDir::homePath() + "/Application Data/qet/qet_tb_generator.exe", {("")});
|
||||
success = process->startDetached(QDir::homePath() + "/Application Data/qet/qet_tb_generator.exe");
|
||||
}
|
||||
if (openedProjects().count()){
|
||||
success = process->startDetached(QDir::homePath() + "/qet_tb_generator.exe", {(QETDiagramEditor::currentProjectView()->project()->filePath())});
|
||||
}
|
||||
else {
|
||||
success = process->startDetached(QDir::homePath() + "/qet_tb_generator.exe", {("")});
|
||||
success = process->startDetached(QDir::homePath() + "/qet_tb_generator.exe");
|
||||
}
|
||||
|
||||
#elif defined(Q_OS_MAC)
|
||||
@@ -2240,13 +2240,13 @@ void QETDiagramEditor::generateTerminalBlock()
|
||||
success = process->startDetached("/Library/Frameworks/Python.framework/Versions/3.8/bin/qet_tb_generator", {(QETDiagramEditor::currentProjectView()->project()->filePath())});
|
||||
}
|
||||
else {
|
||||
success = process->startDetached("/Library/Frameworks/Python.framework/Versions/3.8/bin/qet_tb_generator", {("")});
|
||||
success = process->startDetached("/Library/Frameworks/Python.framework/Versions/3.8/bin/qet_tb_generator");
|
||||
}
|
||||
if (openedProjects().count()){
|
||||
success = process->startDetached(QDir::homePath() + "/.qet/qet_tb_generator.app", {(QETDiagramEditor::currentProjectView()->project()->filePath())});
|
||||
}
|
||||
else {
|
||||
success = process->startDetached(QDir::homePath() + "/.qet/qet_tb_generator.app", {("")});
|
||||
success = process->startDetached(QDir::homePath() + "/.qet/qet_tb_generator.app");
|
||||
}
|
||||
|
||||
#else
|
||||
@@ -2254,13 +2254,13 @@ void QETDiagramEditor::generateTerminalBlock()
|
||||
success = process->startDetached("qet_tb_generator", {(QETDiagramEditor::currentProjectView()->project()->filePath())});
|
||||
}
|
||||
else {
|
||||
success = process->startDetached("qet_tb_generator", {("")});
|
||||
success = process->startDetached("qet_tb_generator");
|
||||
}
|
||||
if (openedProjects().count()){
|
||||
success = process->startDetached(QDir::homePath() + "/.qet/qet_tb_generator", {(QETDiagramEditor::currentProjectView()->project()->filePath())});
|
||||
}
|
||||
else {
|
||||
success = process->startDetached(QDir::homePath() + "/.qet/qet_tb_generator", {("")});
|
||||
success = process->startDetached(QDir::homePath() + "/.qet/qet_tb_generator");
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
@@ -309,6 +309,8 @@ void ProjectDBModel::dataBaseUpdated()
|
||||
auto new_record = m_record;
|
||||
m_record = original_record;
|
||||
|
||||
//This a very special case, if this nomenclature model is added
|
||||
//befor any element, column count return 0, so in this case we emit column inserted
|
||||
if (new_record.size() != m_record.size())
|
||||
{
|
||||
emit beginResetModel();
|
||||
|
||||
@@ -61,56 +61,6 @@ void QetGraphicsTableItem::adjustTableToFolio(QetGraphicsTableItem *table, QMarg
|
||||
table->setDisplayNRow(int(floor(available_height/min_row_height))); //Convert a double to int, but max_row_to_display is already rounded an integer so we assume everything is ok
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief QetGraphicsTableItem::checkInsufficientRowsCount
|
||||
* Check if the number of rows of @table + linked table is enough to display all
|
||||
* content of the model, if not open a dialog to advise user what to do.
|
||||
* @param table
|
||||
*/
|
||||
void QetGraphicsTableItem::checkInsufficientRowsCount(QetGraphicsTableItem *table)
|
||||
{
|
||||
if (!table->diagram() || !table->model()) {
|
||||
return;
|
||||
}
|
||||
|
||||
auto first_table = table;
|
||||
while (first_table->previousTable())
|
||||
first_table = first_table->previousTable();
|
||||
|
||||
if (first_table->displayNRow() <= 0) //displayed rows is unlimited
|
||||
return;
|
||||
|
||||
int count_ = first_table->displayNRow();
|
||||
bool several_table = false;
|
||||
while (first_table->nextTable())
|
||||
{
|
||||
several_table = true;
|
||||
first_table = first_table->nextTable();
|
||||
if (first_table->displayNRow() <= 0) { //displayed rows is unlimited
|
||||
return;
|
||||
} else {
|
||||
count_ += first_table->displayNRow();
|
||||
first_table->displayNRowOffset();
|
||||
}
|
||||
}
|
||||
|
||||
if (count_ < first_table->model()->rowCount())
|
||||
{
|
||||
QWidget *parent = first_table->diagram()->views().first() ? first_table->diagram()->views().first() : nullptr;
|
||||
|
||||
QString text;
|
||||
if (several_table) {
|
||||
text = tr("Les information à afficher sont supérieurs à la quantité maximal pouvant être affiché par les tableaux.\n"
|
||||
"Veuillez ajouter un nouveau tableau ou regler les tableaux existant afin d'afficher l'integralité des informations.");
|
||||
} else {
|
||||
text = tr("Les information à afficher sont supérieurs à la quantité maximal pouvant être affiché par le tableau.\n"
|
||||
"Veuillez ajouter un nouveau tableau ou regler le tableau existant afin d'afficher l'integralité des informations.");
|
||||
}
|
||||
QMessageBox::information(parent, tr("Limitation de tableau"), text);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief QetGraphicsTableItem::QetGraphicsTableItem
|
||||
* Default constructor
|
||||
@@ -651,10 +601,6 @@ QVariant QetGraphicsTableItem::itemChange(QGraphicsItem::GraphicsItemChange chan
|
||||
void QetGraphicsTableItem::modelReseted() {
|
||||
dataChanged(m_model->index(0,0), m_model->index(0,0), QVector<int>());
|
||||
setToMinimumHeight();
|
||||
|
||||
if (!previousTable()) { //this is the head table
|
||||
checkInsufficientRowsCount(this);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
@@ -48,7 +48,6 @@ class QetGraphicsTableItem : public QetGraphicsItem
|
||||
|
||||
public :
|
||||
static void adjustTableToFolio(QetGraphicsTableItem *table, QMargins margins = QMargins(20,20,20,0));
|
||||
static void checkInsufficientRowsCount(QetGraphicsTableItem *first_table);
|
||||
|
||||
public:
|
||||
QetGraphicsTableItem(QGraphicsItem *parent= nullptr);
|
||||
|
||||
@@ -52,8 +52,6 @@ GraphicsTablePropertiesEditor::GraphicsTablePropertiesEditor(QetGraphicsTableIte
|
||||
if (table) {
|
||||
setTable(table);
|
||||
}
|
||||
|
||||
ui->m_info_label->setStyleSheet("QLabel {color : red; }");
|
||||
}
|
||||
|
||||
/**
|
||||
@@ -283,8 +281,6 @@ void GraphicsTablePropertiesEditor::updateUi()
|
||||
}
|
||||
}
|
||||
|
||||
updateInfoLabel();
|
||||
|
||||
auto margin = QETUtils::marginsFromString(m_table_item->model()->headerData(0, Qt::Horizontal, Qt::UserRole+1).toString());
|
||||
ui->m_header_top_margin ->setValue(margin.top());
|
||||
ui->m_header_left_margin ->setValue(margin.left());
|
||||
@@ -310,38 +306,6 @@ void GraphicsTablePropertiesEditor::updateUi()
|
||||
setUpEditConnection();
|
||||
}
|
||||
|
||||
void GraphicsTablePropertiesEditor::updateInfoLabel()
|
||||
{
|
||||
auto table_ = m_table_item;
|
||||
while (table_->previousTable()) { table_ = table_->previousTable();}
|
||||
|
||||
int count_ = 0;
|
||||
bool infinite = false;
|
||||
if (table_->displayNRow() <= 0) {
|
||||
infinite = true;
|
||||
} else {
|
||||
count_ = table_->displayNRow();
|
||||
}
|
||||
|
||||
while (table_->nextTable())
|
||||
{
|
||||
table_ = table_->nextTable();
|
||||
if (table_->displayNRow() <= 0) {
|
||||
infinite = true;
|
||||
} else {
|
||||
count_ += table_->displayNRow();
|
||||
}
|
||||
}
|
||||
|
||||
auto value = m_table_item->model()->rowCount() - count_;
|
||||
if (value > 0 && !infinite) {
|
||||
ui->m_info_label->setText(tr("<center>ATTENTION :</center>\n il manque %1 lignes afin d'afficher l'intégralité des informations").arg(value));
|
||||
ui->m_info_label->show();
|
||||
} else {
|
||||
ui->m_info_label->hide();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* @brief GraphicsTablePropertiesEditor::setUpEditConnection
|
||||
*/
|
||||
@@ -369,12 +333,10 @@ void GraphicsTablePropertiesEditor::setUpEditConnection()
|
||||
m_edit_connection << connect(m_table_button_group, QOverload<int>::of(&QButtonGroup::buttonClicked), this, &GraphicsTablePropertiesEditor::apply);
|
||||
m_edit_connection << connect(m_header_button_group, QOverload<int>::of(&QButtonGroup::buttonClicked), this, &GraphicsTablePropertiesEditor::apply);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.15 or later")
|
||||
m_edit_connection << connect(m_table_button_group, QOverload<int>::of(&QButtonGroup::idClicked), this, &GraphicsTablePropertiesEditor::apply);
|
||||
m_edit_connection << connect(m_header_button_group, QOverload<int>::of(&QButtonGroup::idClicked), this, &GraphicsTablePropertiesEditor::apply);
|
||||
#endif
|
||||
m_edit_connection << connect(ui->m_display_n_row_sb, QOverload<int>::of(&QSpinBox::valueChanged), this, &GraphicsTablePropertiesEditor::apply);
|
||||
m_edit_connection << connect(ui->m_display_n_row_sb, QOverload<int>::of(&QSpinBox::valueChanged), this, &GraphicsTablePropertiesEditor::updateInfoLabel);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -52,7 +52,6 @@ class GraphicsTablePropertiesEditor : public PropertiesEditorWidget
|
||||
void on_m_header_font_pb_clicked();
|
||||
void on_m_table_font_pb_clicked();
|
||||
virtual void updateUi() override;
|
||||
void updateInfoLabel();
|
||||
void on_m_table_name_le_textEdited(const QString &arg1);
|
||||
void on_m_previous_table_cb_activated(int index);
|
||||
void on_m_previous_pb_clicked();
|
||||
|
||||
@@ -7,7 +7,7 @@
|
||||
<x>0</x>
|
||||
<y>0</y>
|
||||
<width>524</width>
|
||||
<height>623</height>
|
||||
<height>600</height>
|
||||
</rect>
|
||||
</property>
|
||||
<property name="windowTitle">
|
||||
@@ -40,17 +40,40 @@
|
||||
<string>Géometrie et lignes</string>
|
||||
</property>
|
||||
<layout class="QGridLayout" name="gridLayout_2" columnstretch="0,0,0,0,0,0,0,0">
|
||||
<item row="1" column="4">
|
||||
<widget class="QSpinBox" name="m_display_n_row_sb">
|
||||
<property name="specialValueText">
|
||||
<string>Toutes</string>
|
||||
<item row="0" column="6">
|
||||
<widget class="QPushButton" name="m_apply_geometry_to_linked_table_pb">
|
||||
<property name="toolTip">
|
||||
<string>Appliquer la géometrie à tous les tableaux liée à celui-ci</string>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>999</number>
|
||||
<property name="text">
|
||||
<string/>
|
||||
</property>
|
||||
<property name="icon">
|
||||
<iconset resource="../../../../qelectrotech.qrc">
|
||||
<normaloff>:/ico/22x22/all_pages.png</normaloff>:/ico/22x22/all_pages.png</iconset>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="6">
|
||||
<item row="1" column="2">
|
||||
<widget class="QSpinBox" name="m_y_pos">
|
||||
<property name="maximum">
|
||||
<number>10000</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="4">
|
||||
<widget class="QComboBox" name="m_previous_table_cb">
|
||||
<property name="insertPolicy">
|
||||
<enum>QComboBox::InsertAtBottom</enum>
|
||||
</property>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Aucun</string>
|
||||
</property>
|
||||
</item>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="6">
|
||||
<widget class="QPushButton" name="m_next_pb">
|
||||
<property name="enabled">
|
||||
<bool>true</bool>
|
||||
@@ -70,19 +93,14 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="4">
|
||||
<widget class="QComboBox" name="m_previous_table_cb">
|
||||
<property name="insertPolicy">
|
||||
<enum>QComboBox::InsertAtBottom</enum>
|
||||
<item row="0" column="2">
|
||||
<widget class="QSpinBox" name="m_x_pos">
|
||||
<property name="maximum">
|
||||
<number>10000</number>
|
||||
</property>
|
||||
<item>
|
||||
<property name="text">
|
||||
<string>Aucun</string>
|
||||
</property>
|
||||
</item>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="0">
|
||||
<item row="0" column="0">
|
||||
<spacer name="horizontalSpacer">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
@@ -95,7 +113,20 @@
|
||||
</property>
|
||||
</spacer>
|
||||
</item>
|
||||
<item row="1" column="5">
|
||||
<item row="1" column="7">
|
||||
<spacer name="horizontalSpacer_2">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="sizeHint" stdset="0">
|
||||
<size>
|
||||
<width>40</width>
|
||||
<height>20</height>
|
||||
</size>
|
||||
</property>
|
||||
</spacer>
|
||||
</item>
|
||||
<item row="0" column="5">
|
||||
<widget class="QPushButton" name="m_auto_geometry_pb">
|
||||
<property name="toolTip">
|
||||
<string>Ajuster le tableau au folio</string>
|
||||
@@ -109,47 +140,7 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="7">
|
||||
<spacer name="horizontalSpacer_2">
|
||||
<property name="orientation">
|
||||
<enum>Qt::Horizontal</enum>
|
||||
</property>
|
||||
<property name="sizeHint" stdset="0">
|
||||
<size>
|
||||
<width>40</width>
|
||||
<height>20</height>
|
||||
</size>
|
||||
</property>
|
||||
</spacer>
|
||||
</item>
|
||||
<item row="2" column="1">
|
||||
<widget class="QLabel" name="label_7">
|
||||
<property name="text">
|
||||
<string>Y :</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="1">
|
||||
<widget class="QLabel" name="label_8">
|
||||
<property name="text">
|
||||
<string>X :</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="2">
|
||||
<widget class="QSpinBox" name="m_x_pos">
|
||||
<property name="maximum">
|
||||
<number>10000</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="4" column="1" colspan="6">
|
||||
<item row="2" column="1" colspan="6">
|
||||
<widget class="QWidget" name="widget_3" native="true">
|
||||
<layout class="QHBoxLayout" name="horizontalLayout_3">
|
||||
<property name="leftMargin">
|
||||
@@ -167,7 +158,47 @@
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="5">
|
||||
<item row="0" column="3">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Lignes à afficher :</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="1">
|
||||
<widget class="QLabel" name="label_8">
|
||||
<property name="text">
|
||||
<string>X :</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="0" column="4">
|
||||
<widget class="QSpinBox" name="m_display_n_row_sb">
|
||||
<property name="specialValueText">
|
||||
<string>Toutes</string>
|
||||
</property>
|
||||
<property name="maximum">
|
||||
<number>999</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="3">
|
||||
<widget class="QLabel" name="label_3">
|
||||
<property name="text">
|
||||
<string>Tableau précédent :</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="5">
|
||||
<widget class="QPushButton" name="m_previous_pb">
|
||||
<property name="enabled">
|
||||
<bool>true</bool>
|
||||
@@ -187,60 +218,16 @@
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="2">
|
||||
<widget class="QSpinBox" name="m_y_pos">
|
||||
<property name="maximum">
|
||||
<number>10000</number>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="6">
|
||||
<widget class="QPushButton" name="m_apply_geometry_to_linked_table_pb">
|
||||
<property name="toolTip">
|
||||
<string>Appliquer la géometrie à tous les tableaux liée à celui-ci</string>
|
||||
</property>
|
||||
<item row="1" column="1">
|
||||
<widget class="QLabel" name="label_7">
|
||||
<property name="text">
|
||||
<string/>
|
||||
</property>
|
||||
<property name="icon">
|
||||
<iconset resource="../../../../qelectrotech.qrc">
|
||||
<normaloff>:/ico/22x22/all_pages.png</normaloff>:/ico/22x22/all_pages.png</iconset>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="2" column="3">
|
||||
<widget class="QLabel" name="label_3">
|
||||
<property name="text">
|
||||
<string>Tableau précédent :</string>
|
||||
<string>Y :</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="1" column="3">
|
||||
<widget class="QLabel" name="label">
|
||||
<property name="text">
|
||||
<string>Lignes à afficher :</string>
|
||||
</property>
|
||||
<property name="alignment">
|
||||
<set>Qt::AlignRight|Qt::AlignTrailing|Qt::AlignVCenter</set>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
<item row="3" column="1" colspan="6">
|
||||
<widget class="QLabel" name="m_info_label">
|
||||
<property name="text">
|
||||
<string>TextLabel</string>
|
||||
</property>
|
||||
<property name="textFormat">
|
||||
<enum>Qt::RichText</enum>
|
||||
</property>
|
||||
<property name="scaledContents">
|
||||
<bool>false</bool>
|
||||
</property>
|
||||
</widget>
|
||||
</item>
|
||||
</layout>
|
||||
</widget>
|
||||
</item>
|
||||
|
||||
@@ -1675,7 +1675,6 @@ QSet<Conductor *> Conductor::relatedPotentialConductors(const bool all_diagram,
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
other_conductors += other_conductors_list_t.toSet();
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
other_conductors += QSet<Conductor*>(other_conductors_list_t.begin(),other_conductors_list_t.end());
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -418,6 +418,7 @@ bool Element::buildFromXml(const QDomElement &xml_def_elmt, int *state)
|
||||
{
|
||||
//Minor workaround to find if there is a "input" tagg as label.
|
||||
//If not, we set the tagg "label" to the first "input.
|
||||
// TODO: Remove in later version begin
|
||||
QList <QDomElement> input_field;
|
||||
bool have_label = false;
|
||||
for (QDomElement input_node = node.firstChildElement("input") ; !input_node.isNull() ; input_node = input_node.nextSiblingElement("input"))
|
||||
@@ -429,8 +430,11 @@ bool Element::buildFromXml(const QDomElement &xml_def_elmt, int *state)
|
||||
have_label = true;
|
||||
}
|
||||
}
|
||||
if(!have_label && !input_field.isEmpty())
|
||||
if(!have_label && !input_field.isEmpty()) {
|
||||
qDebug() << input_field.first().attribute("text");
|
||||
input_field.first().setAttribute("tagg", "label");
|
||||
}
|
||||
// TODO: Remove in later version end
|
||||
|
||||
//Parse the definition
|
||||
for (QDomNode n = node.firstChild() ; !n.isNull() ; n = n.nextSibling())
|
||||
@@ -716,16 +720,21 @@ bool Element::fromXml(QDomElement &e, QHash<int, Terminal *> &table_id_adr, bool
|
||||
} else {
|
||||
setRotation(90*read_ori);
|
||||
}
|
||||
|
||||
// TODO: elementInformations are not read from the diagram section or? Yes see below
|
||||
|
||||
//Befor load the dynamic text field,
|
||||
//we remove the dynamic text field created from the description of this element, to avoid doublons.
|
||||
//#######################################################################################################################
|
||||
//#### START #######################################################################################################
|
||||
//#######################################################################################################################
|
||||
//Before load the dynamic text field,
|
||||
//we remove the dynamic text field created from the description of this element, to avoid doublons.
|
||||
for(DynamicElementTextItem *deti : m_dynamic_text_list)
|
||||
delete deti;
|
||||
m_dynamic_text_list.clear();
|
||||
|
||||
//************************//
|
||||
//***Dynamic texts item***//
|
||||
//************************//
|
||||
// Texts in diagram section
|
||||
for (const QDomElement& qde : QET::findInDomElement(e, "dynamic_texts", DynamicElementTextItem::xmlTagName()))
|
||||
{
|
||||
DynamicElementTextItem *deti = new DynamicElementTextItem(this);
|
||||
@@ -733,20 +742,24 @@ bool Element::fromXml(QDomElement &e, QHash<int, Terminal *> &table_id_adr, bool
|
||||
deti->fromXml(qde);
|
||||
}
|
||||
|
||||
// TODO: remove in later version begin
|
||||
|
||||
//************************//
|
||||
//***Element texts item***//
|
||||
//************************//
|
||||
QList<QDomElement> inputs = QET::findInDomElement(e, "inputs", "input");
|
||||
// Inputs in diagram section
|
||||
QList<QDomElement> inputs = QET::findInDomElement(e, "inputs", "input"); // Inputs in diagram section
|
||||
|
||||
//First case, we check for the text item converted to dynamic text item
|
||||
const QList <DynamicElementTextItem *> conv_deti_list = m_converted_text_from_xml_description.keys();
|
||||
const QList <DynamicElementTextItem *> conv_deti_list = m_converted_text_from_xml_description.keys(); // Texts in element definition (elements collection)
|
||||
QList <DynamicElementTextItem *> successfully_converted;
|
||||
const QList <QDomElement> dom_inputs = inputs;
|
||||
|
||||
for (DynamicElementTextItem *deti : conv_deti_list)
|
||||
|
||||
|
||||
for (DynamicElementTextItem *deti : conv_deti_list) // Texts from element definition (elements collection)
|
||||
{
|
||||
for(const QDomElement& dom_input : dom_inputs)
|
||||
for(const QDomElement& dom_input : dom_inputs) // Inputs in diagram section
|
||||
{
|
||||
//we use the same method used in ElementTextItem::fromXml to compar and know if the input dom element is for one of the text stored.
|
||||
//The comparaison is made from the text position : if the position of the text is the same as the position stored in 'input' dom element
|
||||
@@ -817,7 +830,7 @@ bool Element::fromXml(QDomElement &e, QHash<int, Terminal *> &table_id_adr, bool
|
||||
group->fromXml(qde);
|
||||
}
|
||||
|
||||
//load informations
|
||||
//load elementInformations from diagram section
|
||||
DiagramContext dc;
|
||||
dc.fromXml(e.firstChildElement("elementInformations"), "elementInformation");
|
||||
/**
|
||||
@@ -826,7 +839,6 @@ bool Element::fromXml(QDomElement &e, QHash<int, Terminal *> &table_id_adr, bool
|
||||
* this mean the label was made before commit 4791 (0.51 dev). So we swap the value stored in "label" to "formula" as expected.
|
||||
* @TODO remove this code at version 0.7 or more (probably useless).
|
||||
*/
|
||||
#pragma message("@TODO remove this code for qet 0.7 or later")
|
||||
if (dc["label"].toString().contains("%") && dc["formula"].toString().isNull())
|
||||
{
|
||||
dc.addValue("formula", dc["label"]);
|
||||
@@ -992,6 +1004,12 @@ bool Element::fromXml(QDomElement &e, QHash<int, Terminal *> &table_id_adr, bool
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// TODO: remove in later version end
|
||||
|
||||
//#######################################################################################################################
|
||||
//#### END #######################################################################################################
|
||||
//#######################################################################################################################
|
||||
m_state = QET::GIOK;
|
||||
return(true);
|
||||
}
|
||||
|
||||
@@ -23,13 +23,12 @@
|
||||
#include <QFont>
|
||||
|
||||
/**
|
||||
@brief QETXML::penToXml
|
||||
Write attribute of a QPen in xml element
|
||||
@param parent_document : parent document for create the QDomElement
|
||||
@param pen : the pen to store
|
||||
@return : A QDomElement with the attribute stored.
|
||||
The tagName of QDomeElement is "pen".
|
||||
*/
|
||||
* @brief QETXML::penToXml
|
||||
* Write attribute of a QPen in xml element
|
||||
* @param parent_document : parent document for create the QDomElement
|
||||
* @param pen : the pen to store
|
||||
* @return : A QDomElement with the attribute stored. The tagName of QDomeElement is "pen".
|
||||
*/
|
||||
QDomElement QETXML::penToXml(QDomDocument &parent_document,const QPen& pen)
|
||||
{
|
||||
QDomElement element = parent_document.createElement("pen");
|
||||
@@ -49,19 +48,19 @@ QDomElement QETXML::penToXml(QDomDocument &parent_document,const QPen& pen)
|
||||
element.setAttribute("style", style);
|
||||
element.setAttribute("color", pen.color().name());
|
||||
element.setAttribute("widthF", QString::number(pen.widthF()));
|
||||
return element;
|
||||
return element;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::penFromXml
|
||||
Build a QPen from a xml description
|
||||
@param element, The QDomElement that describe the pen
|
||||
@return the created pen. If @element is null or tagName isn't "pen"
|
||||
return a default constructed QPen
|
||||
*/
|
||||
* @brief QETXML::penFromXml
|
||||
* Build a QPen from a xml description
|
||||
* @param element, The QDomElement that describe the pen
|
||||
* @return the created pen. If @element is null or tagName isn't "pen"
|
||||
* return a default constructed QPen
|
||||
*/
|
||||
QPen QETXML::penFromXml(const QDomElement &element)
|
||||
{
|
||||
QPen pen;
|
||||
QPen pen;
|
||||
|
||||
if (!(!element.isNull() && element.tagName() == "pen"))
|
||||
{
|
||||
@@ -83,19 +82,17 @@ QPen QETXML::penFromXml(const QDomElement &element)
|
||||
|
||||
pen.setColor(QColor(element.attribute("color", "#000000")));
|
||||
pen.setWidthF(element.attribute("widthF", "1").toDouble());
|
||||
return pen;
|
||||
return pen;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::brushToXml
|
||||
Write attribute of a QBrush in xml element
|
||||
@param parent_document : parent document for create the QDomElement
|
||||
@param brush : the brush to store
|
||||
@return A QDomElement with the attribute stored.
|
||||
The tagName of QDomeElement is "brush".
|
||||
*/
|
||||
QDomElement QETXML::brushToXml(QDomDocument &parent_document,
|
||||
const QBrush& brush)
|
||||
* @brief QETXML::brushToXml
|
||||
* Write attribute of a QBrush in xml element
|
||||
* @param parent_document : parent document for create the QDomElement
|
||||
* @param brush : the brush to store
|
||||
* @return A QDomElement with the attribute stored. The tagName of QDomeElement is "brush".
|
||||
*/
|
||||
QDomElement QETXML::brushToXml(QDomDocument &parent_document, const QBrush& brush)
|
||||
{
|
||||
QDomElement element = parent_document.createElement("brush");
|
||||
|
||||
@@ -117,7 +114,7 @@ QDomElement QETXML::brushToXml(QDomDocument &parent_document,
|
||||
case Qt::BDiagPattern : style = "BDiagPattern"; break;
|
||||
case Qt::FDiagPattern : style = "FDiagPattern"; break;
|
||||
case Qt::DiagCrossPattern : style = "DiagCrossPattern"; break;
|
||||
default : style = "Unknown"; break;
|
||||
default : style = "Unknown"; break;
|
||||
}
|
||||
|
||||
element.setAttribute("style", style);
|
||||
@@ -126,12 +123,12 @@ QDomElement QETXML::brushToXml(QDomDocument &parent_document,
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::brushFromXml
|
||||
Build a QBrush from a xml description
|
||||
@param element, the QDomElement that describe the pen
|
||||
@return the created brush. If @element is null or tagName isn't "brush"
|
||||
return a default constructed QBrush
|
||||
*/
|
||||
* @brief QETXML::brushFromXml
|
||||
* Build a QBrush from a xml description
|
||||
* @param element, the QDomElement that describe the pen
|
||||
* @return the created brush. If @element is null or tagName isn't "brush"
|
||||
* return a default constructed QBrush
|
||||
*/
|
||||
QBrush QETXML::brushFromXml(const QDomElement &element)
|
||||
{
|
||||
QBrush brush;
|
||||
@@ -161,20 +158,15 @@ QBrush QETXML::brushFromXml(const QDomElement &element)
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::fileSystemDirToXmlCollectionDir
|
||||
@param document : owner document of returned QDomElement,
|
||||
use to create the QDomElement.
|
||||
@param dir : file system direcory to convert to QDomElement directory
|
||||
@param rename : by default the attribute "name" of the returned
|
||||
QDomElement is the same name of @dir
|
||||
but we can override itwith @rename
|
||||
@return A file system directory converted to a QDomElement directory
|
||||
ready to be inserted into a XmlElementCollection.
|
||||
If the QDomElement can't be created, return a null QDomElement.
|
||||
*/
|
||||
QDomElement QETXML::fileSystemDirToXmlCollectionDir(QDomDocument &document,
|
||||
const QDir &dir,
|
||||
const QString& rename)
|
||||
* @brief QETXML::fileSystemDirToXmlCollectionDir
|
||||
* @param document : owner document of returned QDomElement, use to create the QDomElement.
|
||||
* @param dir : file system direcory to convert to QDomElement directory
|
||||
* @param rename : by default the attribute "name" of the returned QDomElement is the same name of @dir
|
||||
* but we can override itwith @rename
|
||||
* @return A file system directory converted to a QDomElement directory ready to be inserted into a XmlElementCollection.
|
||||
* If the QDomElement can't be created, return a null QDomElement.
|
||||
*/
|
||||
QDomElement QETXML::fileSystemDirToXmlCollectionDir(QDomDocument &document, const QDir &dir, const QString& rename)
|
||||
{
|
||||
if (!dir.exists()) return QDomElement();
|
||||
|
||||
@@ -183,9 +175,7 @@ QDomElement QETXML::fileSystemDirToXmlCollectionDir(QDomDocument &document,
|
||||
|
||||
//Get the traduction of this directory
|
||||
QFile qet_dir(dir.filePath("qet_directory"));
|
||||
if (qet_dir.exists() && qet_dir.open(
|
||||
QIODevice::ReadOnly
|
||||
| QIODevice::Text))
|
||||
if (qet_dir.exists() && qet_dir.open(QIODevice::ReadOnly | QIODevice::Text))
|
||||
{
|
||||
//Get the content of the file
|
||||
QDomDocument trad_document;
|
||||
@@ -206,21 +196,15 @@ QDomElement QETXML::fileSystemDirToXmlCollectionDir(QDomDocument &document,
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::fileSystemElementToXmlCollectionElement
|
||||
@param document : owner document of returned QDomElement,
|
||||
use to create the QDomElement.
|
||||
@param file : file system element file to convert to QDomElement;
|
||||
@param rename : by default the attribute "name" of
|
||||
the returned QDomElement is the same name of @file
|
||||
but we can override itwith @rename
|
||||
@return A file system element converted to a QDomElement
|
||||
ready to be inserted into a XmlElementCollection
|
||||
If the QDomElement can't be created, return a null QDomElement
|
||||
*/
|
||||
QDomElement QETXML::fileSystemElementToXmlCollectionElement(
|
||||
QDomDocument &document,
|
||||
QFile &file,
|
||||
const QString& rename)
|
||||
* @brief QETXML::fileSystemElementToXmlCollectionElement
|
||||
* @param document : owner document of returned QDomElement, use to create the QDomElement.
|
||||
* @param file : file system element file to convert to QDomElement;
|
||||
* @param rename : by default the attribute "name" of the returned QDomElement is the same name of @file
|
||||
* but we can override itwith @rename
|
||||
* @return A file system element converted to a QDomElement ready to be inserted into a XmlElementCollection
|
||||
* If the QDomElement can't be created, return a null QDomElement
|
||||
*/
|
||||
QDomElement QETXML::fileSystemElementToXmlCollectionElement(QDomDocument &document, QFile &file, const QString& rename)
|
||||
{
|
||||
if (file.exists() && file.open(QIODevice::ReadOnly | QIODevice::Text))
|
||||
{
|
||||
@@ -245,32 +229,26 @@ QDomElement QETXML::fileSystemElementToXmlCollectionElement(
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::writeXmlFile
|
||||
Export an XML document to an UTF-8 text file indented with 4 spaces,
|
||||
with LF end of lines and no BOM.
|
||||
@param xml_document : An XML document to be exported
|
||||
@param file_path : Path to the file to be written
|
||||
@param error_message : If non-zero, will contain an error message
|
||||
explaining what happened when this function returns false.
|
||||
@return false if an error occurred, true otherwise
|
||||
*/
|
||||
bool QETXML::writeXmlFile(const QDomDocument &xml_document,
|
||||
const QString &file_path,
|
||||
QString *error_message)
|
||||
* @brief QETXML::writeXmlFile
|
||||
* Export an XML document to an UTF-8 text file indented with 4 spaces, with LF end of lines and no BOM.
|
||||
* @param xml_document : An XML document to be exported
|
||||
* @param file_path : Path to the file to be written
|
||||
* @param error_message : If non-zero, will contain an error message explaining what happened when this function returns false.
|
||||
* @return false if an error occurred, true otherwise
|
||||
*/
|
||||
bool QETXML::writeXmlFile(const QDomDocument &xml_document, const QString &file_path, QString *error_message)
|
||||
{
|
||||
QFile file(file_path);
|
||||
|
||||
// Note: we do not set QIODevice::Text to avoid generating CRLF end of lines
|
||||
// Note: we do not set QIODevice::Text to avoid generating CRLF end of lines
|
||||
bool file_opening = file.open(QIODevice::WriteOnly);
|
||||
if (!file_opening)
|
||||
{
|
||||
if (error_message)
|
||||
{
|
||||
*error_message = QString(
|
||||
QObject::tr(
|
||||
"Impossible d'ouvrir le fichier %1 en écriture, erreur %2 rencontrée.",
|
||||
"error message when attempting to write an XML file")
|
||||
).arg(file_path).arg(file.error());
|
||||
*error_message = QString(QObject::tr("Impossible d'ouvrir le fichier %1 en écriture, erreur %2 rencontrée.",
|
||||
"error message when attempting to write an XML file")
|
||||
).arg(file_path).arg(file.error());
|
||||
}
|
||||
return(false);
|
||||
}
|
||||
@@ -285,17 +263,14 @@ bool QETXML::writeXmlFile(const QDomDocument &xml_document,
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::textToDomElement
|
||||
Return a QDomElement, created from @document,
|
||||
with tag name @tag_name and text @value.
|
||||
@param document
|
||||
@param tag_name
|
||||
@param value
|
||||
@return a QDomElement, created from @document
|
||||
*/
|
||||
QDomElement QETXML::textToDomElement(QDomDocument &document,
|
||||
const QString& tag_name,
|
||||
const QString& value)
|
||||
* @brief QETXML::textToDomElement
|
||||
* Return a QDomElement, created from @document, with tag name @tag_name and text @value.
|
||||
* @param document
|
||||
* @param tag_name
|
||||
* @param value
|
||||
* @return
|
||||
*/
|
||||
QDomElement QETXML::textToDomElement(QDomDocument &document, const QString& tag_name, const QString& value)
|
||||
{
|
||||
QDomElement element = document.createElement(tag_name);
|
||||
QDomText text = document.createTextNode(value);
|
||||
@@ -305,19 +280,15 @@ QDomElement QETXML::textToDomElement(QDomDocument &document,
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::directChild
|
||||
@param element
|
||||
@param tag_name
|
||||
@return All direct child of @element with the tag name @tag_name
|
||||
*/
|
||||
QVector<QDomElement> QETXML::directChild(const QDomElement &element,
|
||||
const QString &tag_name)
|
||||
* @brief QETXML::directChild
|
||||
* @param element
|
||||
* @param tag_name
|
||||
* @return All direct child of @element with the tag name @tag_name
|
||||
*/
|
||||
QVector<QDomElement> QETXML::directChild(const QDomElement &element, const QString &tag_name)
|
||||
{
|
||||
QVector<QDomElement> return_list;
|
||||
for (
|
||||
QDomNode node = element.firstChild() ;
|
||||
!node.isNull() ;
|
||||
node = node.nextSibling())
|
||||
for (QDomNode node = element.firstChild() ; !node.isNull() ; node = node.nextSibling())
|
||||
{
|
||||
if (!node.isElement()) continue;
|
||||
QDomElement element = node.toElement();
|
||||
@@ -329,34 +300,25 @@ QVector<QDomElement> QETXML::directChild(const QDomElement &element,
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::subChild
|
||||
@param element
|
||||
@param parent_tag_name
|
||||
@param children_tag_name
|
||||
@return When given an xml dom element @element,
|
||||
returns a vector of all children dom_elements tagged @children_tag_name
|
||||
nested in the parent dom elements tagged parent_tag_name,
|
||||
themselves children of the dom element @element.
|
||||
*/
|
||||
QVector<QDomElement> QETXML::subChild(const QDomElement &element,
|
||||
const QString parent_tag_name,
|
||||
const QString &children_tag_name)
|
||||
* @brief QETXML::subChild
|
||||
* @param element
|
||||
* @param parent_tag_name
|
||||
* @param children_tag_name
|
||||
* @return When given an xml dom element @element,
|
||||
* returns a vector of all children dom_elements tagged @children_tag_name
|
||||
* nested in the parent dom elements tagged parent_tag_name, themselves children of the dom element @element.
|
||||
*/
|
||||
QVector<QDomElement> QETXML::subChild(const QDomElement &element, const QString parent_tag_name, const QString &children_tag_name)
|
||||
{
|
||||
QVector<QDomElement> return_list;
|
||||
|
||||
for (
|
||||
QDomNode child = element.firstChild() ;
|
||||
!child.isNull() ;
|
||||
child = child.nextSibling())
|
||||
for (QDomNode child = element.firstChild() ; !child.isNull() ; child = child.nextSibling())
|
||||
{
|
||||
QDomElement parents = child.toElement();
|
||||
if (parents.isNull() || parents.tagName() != parent_tag_name)
|
||||
continue;
|
||||
|
||||
for (
|
||||
QDomNode node_children = parents.firstChild() ;
|
||||
!node_children.isNull() ;
|
||||
node_children = node_children.nextSibling())
|
||||
for (QDomNode node_children = parents.firstChild() ; !node_children.isNull() ; node_children = node_children.nextSibling())
|
||||
{
|
||||
QDomElement n_children = node_children.toElement();
|
||||
if (!n_children.isNull() && n_children.tagName() == children_tag_name)
|
||||
@@ -368,34 +330,29 @@ QVector<QDomElement> QETXML::subChild(const QDomElement &element,
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::marginsToXml
|
||||
Save a QMargins to xml. the xml tag name is 'margins'
|
||||
@param parent_document
|
||||
@param margins
|
||||
@return
|
||||
*/
|
||||
QDomElement QETXML::marginsToXml(QDomDocument &parent_document,
|
||||
const QMargins &margins)
|
||||
* @brief QETXML::marginsToXml
|
||||
* Save a QMargins to xml. the xml tag name is 'margins'
|
||||
* @param parent_document
|
||||
* @param margins
|
||||
* @return
|
||||
*/
|
||||
QDomElement QETXML::marginsToXml(QDomDocument &parent_document, const QMargins &margins)
|
||||
{
|
||||
auto dom_ = parent_document.createElement("margins");
|
||||
auto text_ = parent_document.createTextNode(
|
||||
QString::number(margins.left())
|
||||
+ QString(";")
|
||||
+ QString::number(margins.top())
|
||||
+ QString(";")
|
||||
+ QString::number(margins.right())
|
||||
+ QString(";")
|
||||
+ QString::number(margins.bottom()));
|
||||
auto text_ = parent_document.createTextNode(QString::number(margins.left()) + QString(";") +
|
||||
QString::number(margins.top()) + QString(";") +
|
||||
QString::number(margins.right()) + QString(";") +
|
||||
QString::number(margins.bottom()));
|
||||
dom_.appendChild(text_);
|
||||
return dom_;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::marginsFromXml
|
||||
@param element
|
||||
@return a QMargins from an xml description.
|
||||
The tag name must ne 'margins'
|
||||
*/
|
||||
* @brief QETXML::marginsFromXml
|
||||
* @param element
|
||||
* @return a QMargins from an xml description.
|
||||
* The tag name must ne 'margins'
|
||||
*/
|
||||
QMargins QETXML::marginsFromXml(const QDomElement &element)
|
||||
{
|
||||
if (element.tagName() != "margins") {
|
||||
@@ -404,35 +361,22 @@ QMargins QETXML::marginsFromXml(const QDomElement &element)
|
||||
|
||||
auto margins_ = element.text().split(";");
|
||||
if (margins_.size() == 4) {
|
||||
return QMargins(
|
||||
margins_.at(0).toInt(),
|
||||
margins_.at(1).toInt(),
|
||||
margins_.at(2).toInt(),
|
||||
margins_.at(3).toInt());
|
||||
return QMargins(margins_.at(0).toInt(), margins_.at(1).toInt(), margins_.at(2).toInt(), margins_.at(3).toInt());
|
||||
} else {
|
||||
return QMargins();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::modelHeaderDataToXml
|
||||
Save to xml element all header data specified
|
||||
by @horizontal_section_role and @vertical_section_role
|
||||
@param parent_document
|
||||
@param model
|
||||
@param horizontal_section_role : key as header section and value
|
||||
as list of roles to save in xml
|
||||
@param vertical_section_role :key as header section and value
|
||||
as list of roles to save in xml
|
||||
@return
|
||||
*/
|
||||
QDomElement QETXML::modelHeaderDataToXml(
|
||||
QDomDocument &parent_document,
|
||||
const QAbstractItemModel *model,
|
||||
QHash<int,
|
||||
QList<int>> horizontal_section_role,
|
||||
QHash<int,
|
||||
QList<int>> vertical_section_role)
|
||||
* @brief QETXML::modelHeaderDataToXml
|
||||
* Save to xml element all header data specified by @horizontal_section_role and @vertical_section_role
|
||||
* @param parent_document
|
||||
* @param model
|
||||
* @param horizontal_section_role : key as header section and value as list of roles to save in xml
|
||||
* @param vertical_section_role :key as header section and value as list of roles to save in xml
|
||||
* @return
|
||||
*/
|
||||
QDomElement QETXML::modelHeaderDataToXml(QDomDocument &parent_document, const QAbstractItemModel *model, QHash<int, QList<int>> horizontal_section_role, QHash<int, QList<int>> vertical_section_role)
|
||||
{
|
||||
auto dom_element = parent_document.createElement("header_data");
|
||||
|
||||
@@ -457,11 +401,7 @@ QDomElement QETXML::modelHeaderDataToXml(
|
||||
dom_data.setAttribute("role", meta_enum_role.valueToKey(role));
|
||||
|
||||
auto text_node = parent_document.createTextNode("");
|
||||
if (role == Qt::DisplayRole
|
||||
|| role == Qt::EditRole
|
||||
|| role == Qt::ToolTipRole
|
||||
|| role == Qt::StatusTipRole
|
||||
|| role == Qt::WhatsThisRole)
|
||||
if (role == Qt::DisplayRole || role == Qt::EditRole || role == Qt::ToolTipRole || role == Qt::StatusTipRole || role == Qt::WhatsThisRole)
|
||||
{
|
||||
text_node.setData(variant.toString());
|
||||
}
|
||||
@@ -493,13 +433,12 @@ QDomElement QETXML::modelHeaderDataToXml(
|
||||
}
|
||||
|
||||
/**
|
||||
@brief QETXML::modelHeaderDataFromXml
|
||||
Restore from xml modele header data
|
||||
@param element
|
||||
@param model
|
||||
*/
|
||||
void QETXML::modelHeaderDataFromXml(const QDomElement &element,
|
||||
QAbstractItemModel *model)
|
||||
* @brief QETXML::modelHeaderDataFromXml
|
||||
* Restore from xml modele header data
|
||||
* @param element
|
||||
* @param model
|
||||
*/
|
||||
void QETXML::modelHeaderDataFromXml(const QDomElement &element, QAbstractItemModel *model)
|
||||
{
|
||||
if (element.tagName() != "header_data")
|
||||
return;
|
||||
@@ -510,25 +449,12 @@ void QETXML::modelHeaderDataFromXml(const QDomElement &element,
|
||||
for (auto child : QETXML::directChild(element, "data"))
|
||||
{
|
||||
auto section_ = child.attribute("section", "-1").toInt();
|
||||
auto orientation_ = Qt::Orientation(
|
||||
meta_enum_orientation.keyToValue(
|
||||
child.attribute(
|
||||
"orientation",
|
||||
"Horizontal"
|
||||
).toStdString().data()));
|
||||
auto role_ = meta_enum_role.keyToValue(
|
||||
child.attribute(
|
||||
"role",
|
||||
"DisplayRole"
|
||||
).toStdString().data());
|
||||
auto orientation_ = Qt::Orientation(meta_enum_orientation.keyToValue(child.attribute("orientation", "Horizontal").toStdString().data()));
|
||||
auto role_ = meta_enum_role.keyToValue(child.attribute("role", "DisplayRole").toStdString().data());
|
||||
auto text_ = child.text();
|
||||
QVariant data_;
|
||||
|
||||
if (role_ == Qt::DisplayRole
|
||||
|| role_ == Qt::EditRole
|
||||
|| role_ == Qt::ToolTipRole
|
||||
|| role_ == Qt::StatusTipRole
|
||||
|| role_ == Qt::WhatsThisRole) {
|
||||
if (role_ == Qt::DisplayRole || role_ == Qt::EditRole || role_ == Qt::ToolTipRole || role_ == Qt::StatusTipRole || role_ == Qt::WhatsThisRole) {
|
||||
data_ = text_;
|
||||
}
|
||||
else if (role_ == Qt::FontRole)
|
||||
|
||||
@@ -31,48 +31,27 @@ class QAbstractItemModel;
|
||||
*/
|
||||
namespace QETXML
|
||||
{
|
||||
QDomElement penToXml(QDomDocument &parent_document, const QPen& pen);
|
||||
QPen penFromXml (const QDomElement &element);
|
||||
QDomElement penToXml(QDomDocument &parent_document, const QPen& pen);
|
||||
QPen penFromXml (const QDomElement &element);
|
||||
|
||||
QDomElement brushToXml (QDomDocument &parent_document,
|
||||
const QBrush& brush);
|
||||
QDomElement brushToXml (QDomDocument &parent_document, const QBrush& brush);
|
||||
QBrush brushFromXml (const QDomElement &element);
|
||||
|
||||
QDomElement fileSystemDirToXmlCollectionDir (
|
||||
QDomDocument &document,
|
||||
const QDir &dir,
|
||||
const QString& rename = QString());
|
||||
QDomElement fileSystemElementToXmlCollectionElement (
|
||||
QDomDocument &document,
|
||||
QFile &file,
|
||||
const QString& rename = QString());
|
||||
QDomElement fileSystemDirToXmlCollectionDir (QDomDocument &document, const QDir &dir, const QString& rename = QString());
|
||||
QDomElement fileSystemElementToXmlCollectionElement (QDomDocument &document, QFile &file, const QString& rename = QString());
|
||||
|
||||
bool writeXmlFile(const QDomDocument &xml_document,
|
||||
const QString &file_path,
|
||||
QString *error_message = nullptr);
|
||||
bool writeXmlFile(const QDomDocument &xml_document, const QString &file_path, QString *error_message = nullptr);
|
||||
|
||||
QDomElement textToDomElement (QDomDocument &document,
|
||||
const QString& tag_name,
|
||||
const QString& value);
|
||||
QDomElement textToDomElement (QDomDocument &document, const QString& tag_name, const QString& value);
|
||||
|
||||
QVector <QDomElement> directChild(const QDomElement &element,
|
||||
const QString &tag_name);
|
||||
QVector <QDomElement> subChild(const QDomElement &element,
|
||||
const QString parent_tag_name,
|
||||
const QString &children_tag_name);
|
||||
QVector <QDomElement> directChild(const QDomElement &element, const QString &tag_name);
|
||||
QVector <QDomElement> subChild(const QDomElement &element, const QString parent_tag_name, const QString &children_tag_name);
|
||||
|
||||
QDomElement marginsToXml (QDomDocument &parent_document,
|
||||
const QMargins &margins);
|
||||
QDomElement marginsToXml (QDomDocument &parent_document, const QMargins &margins);
|
||||
QMargins marginsFromXml(const QDomElement &element);
|
||||
|
||||
QDomElement modelHeaderDataToXml(QDomDocument &parent_document,
|
||||
const QAbstractItemModel *model,
|
||||
QHash<int,
|
||||
QList<int>> horizontal_section_role,
|
||||
QHash<int,
|
||||
QList<int>> vertical_section_role);
|
||||
void modelHeaderDataFromXml(const QDomElement &element,
|
||||
QAbstractItemModel *model);
|
||||
QDomElement modelHeaderDataToXml(QDomDocument &parent_document, const QAbstractItemModel *model, QHash<int, QList<int>> horizontal_section_role, QHash<int, QList<int>> vertical_section_role);
|
||||
void modelHeaderDataFromXml(const QDomElement &element, QAbstractItemModel *model);
|
||||
}
|
||||
|
||||
#endif // QETXML_H
|
||||
|
||||
@@ -739,7 +739,6 @@ QString RichTextEditor::text(Qt::TextFormat format) const
|
||||
break;
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0)
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
case Qt::MarkdownText: //This enum value was added in Qt 5.14.
|
||||
break;
|
||||
#endif
|
||||
|
||||
@@ -338,7 +338,6 @@ void TitleBlockTemplate::parseRows(const QString &rows_string) {
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
QStringList rows_descriptions = rows_string.split(QChar(';'), QString::SkipEmptyParts);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
QStringList rows_descriptions = rows_string.split(QChar(';'), Qt::SkipEmptyParts);
|
||||
#endif
|
||||
foreach (QString rows_description, rows_descriptions) {
|
||||
@@ -366,7 +365,6 @@ void TitleBlockTemplate::parseColumns(const QString &cols_string) {
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 14, 0) // ### Qt 6: remove
|
||||
QStringList cols_descriptions = cols_string.split(QChar(';'), QString::SkipEmptyParts);
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.14 or later")
|
||||
QStringList cols_descriptions = cols_string.split(QChar(';'), Qt::SkipEmptyParts);
|
||||
#endif
|
||||
foreach (QString cols_description, cols_descriptions) {
|
||||
|
||||
@@ -21,13 +21,7 @@
|
||||
|
||||
#include <QThread>
|
||||
#include <QDate>
|
||||
#include <QScreen>
|
||||
#include <QProcess>
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::AboutQETDialog
|
||||
@param parent
|
||||
*/
|
||||
AboutQETDialog::AboutQETDialog(QWidget *parent) :
|
||||
QDialog(parent),
|
||||
ui(new Ui::AboutQETDialog)
|
||||
@@ -42,17 +36,11 @@ AboutQETDialog::AboutQETDialog(QWidget *parent) :
|
||||
setLicence();
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::~AboutQETDialog
|
||||
*/
|
||||
AboutQETDialog::~AboutQETDialog()
|
||||
{
|
||||
delete ui;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::setAbout
|
||||
*/
|
||||
void AboutQETDialog::setAbout()
|
||||
{
|
||||
|
||||
@@ -67,9 +55,6 @@ void AboutQETDialog::setAbout()
|
||||
ui->m_about_label->setText(str);
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::setAuthors
|
||||
*/
|
||||
void AboutQETDialog::setAuthors()
|
||||
{
|
||||
addAuthor(ui->m_author_label, "Benoît Ansieau", "benoit@qelectrotech.org", tr("Idée originale"));
|
||||
@@ -81,9 +66,6 @@ void AboutQETDialog::setAuthors()
|
||||
addAuthor(ui->m_author_label, "Abhishek Bansal", "abhishek@qelectrotech.org", tr("Développement"));
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::setTranslators
|
||||
*/
|
||||
void AboutQETDialog::setTranslators()
|
||||
{
|
||||
addAuthor(ui->m_translators_label, "Alfredo Carreto", "electronicos_mx@yahoo.com.mx", tr("Traduction en espagnol"));
|
||||
@@ -112,9 +94,6 @@ void AboutQETDialog::setTranslators()
|
||||
addAuthor(ui->m_translators_label, "Gábor Gubányi", "gubanyig@gmail.com", tr("Traduction en hongrois"));
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::setContributors
|
||||
*/
|
||||
void AboutQETDialog::setContributors()
|
||||
{
|
||||
addAuthor(ui->m_contrib_label, "Remi Collet", "remi@fedoraproject.org", tr("Paquets Fedora et Red Hat"));
|
||||
@@ -138,9 +117,6 @@ void AboutQETDialog::setContributors()
|
||||
addAuthor(ui->m_contrib_label, "Maximilian Federle", "", tr("Paquets Snap"));
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::setVersion
|
||||
*/
|
||||
void AboutQETDialog::setVersion()
|
||||
{
|
||||
QString str = "<span style=\"font-weight:bold;font-size:16pt;\">QElectroTech V " + QET::displayedVersion + "</span>";
|
||||
@@ -153,12 +129,6 @@ void AboutQETDialog::setVersion()
|
||||
compilation_info += " : " + QString(__TIME__);
|
||||
compilation_info += " <br>Run with Qt "+ QString(qVersion());
|
||||
compilation_info += " using" + QString(" %1 thread(s)").arg(QThread::idealThreadCount());
|
||||
QProcess macoscpuinfo;
|
||||
macoscpuinfo.start("bash", QStringList() << "-c" << "sysctl -n machdep.cpu.brand_string");
|
||||
macoscpuinfo.waitForFinished();
|
||||
QString macosOutput = macoscpuinfo.readAllStandardOutput();
|
||||
compilation_info += "<br>"" CPU : " + QString(macosOutput.toLocal8Bit().constData());
|
||||
|
||||
compilation_info += "<br>" " OS : " + QString(QSysInfo::kernelType());
|
||||
compilation_info += " - " + QString(QSysInfo::currentCpuArchitecture());
|
||||
compilation_info += " - Version : " + QString(QSysInfo::prettyProductName());
|
||||
@@ -170,61 +140,15 @@ void AboutQETDialog::setVersion()
|
||||
compilation_info += " : " + QString(__TIME__);
|
||||
compilation_info += " <br>Run with Qt "+ QString(qVersion());
|
||||
compilation_info += " using" + QString(" %1 thread(s)").arg(QThread::idealThreadCount());
|
||||
|
||||
QString OSName = QSysInfo::kernelType();
|
||||
if (OSName == "linux")
|
||||
{
|
||||
QProcess linuxcpuinfo;
|
||||
linuxcpuinfo.start("bash", QStringList() << "-c" << "cat /proc/cpuinfo |grep 'model name' | uniq");
|
||||
linuxcpuinfo.waitForFinished();
|
||||
QString linuxOutput = linuxcpuinfo.readAllStandardOutput();
|
||||
compilation_info += "<br>"" CPU : " + QString(linuxOutput.toLocal8Bit().constData());
|
||||
|
||||
QProcess p;
|
||||
p.start("awk", QStringList() << "/MemTotal/ { print $2 }" << "/proc/meminfo");
|
||||
p.waitForFinished();
|
||||
QString memory = p.readAllStandardOutput();
|
||||
compilation_info += "<br>" + QString("RAM Total : %1 MB").arg(memory.toLong() / 1024);
|
||||
p.close();
|
||||
|
||||
QProcess qp;
|
||||
qp.start("awk", QStringList() << "/MemAvailable/ {print $2}" << "/proc/meminfo");
|
||||
qp.waitForFinished();
|
||||
QString AvailableMemory = qp.readAllStandardOutput();
|
||||
compilation_info += "<br>" + QString("RAM Available : %1 MB").arg(AvailableMemory.toLong() / 1024);
|
||||
qp.close();
|
||||
|
||||
QProcess linuxgpuinfo;
|
||||
linuxgpuinfo.start("bash", QStringList() << "-c" << "lspci | grep VGA | cut -d : -f 3");
|
||||
linuxgpuinfo.waitForFinished();
|
||||
QString linuxGPUOutput = linuxgpuinfo.readAllStandardOutput();
|
||||
compilation_info += "<br>"" GPU : " + QString(linuxGPUOutput.toLocal8Bit().constData());
|
||||
|
||||
}
|
||||
|
||||
compilation_info += "<br>" " OS : " + QString(QSysInfo::kernelType());
|
||||
compilation_info += " - " + QString(QSysInfo::currentCpuArchitecture());
|
||||
compilation_info += " - Version : " + QString(QSysInfo::prettyProductName());
|
||||
compilation_info += "</br>" " - Kernel : " + QString(QSysInfo::kernelVersion());
|
||||
#endif
|
||||
#endif
|
||||
compilation_info += "<br> *** Qt screens *** </br>";
|
||||
const auto screens = qApp->screens();
|
||||
for (int ii = 0; ii < screens.count(); ++ii) {
|
||||
compilation_info += "<br> ( "
|
||||
+ QString::number(ii + 1)
|
||||
+ " : "
|
||||
+ QString::number(screens[ii]->geometry().width() * screens[ii]->devicePixelRatio())
|
||||
+ " x "
|
||||
+ QString::number(screens[ii]->geometry().height() * screens[ii]->devicePixelRatio())
|
||||
+ " ) </br>";
|
||||
}
|
||||
ui->m_version_label->setText(str + compilation_info);
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::setLibraries
|
||||
*/
|
||||
void AboutQETDialog::setLibraries()
|
||||
{
|
||||
addLibrary(ui->m_libraries_label, "KDE lib", "https://api.kde.org");
|
||||
@@ -232,22 +156,19 @@ void AboutQETDialog::setLibraries()
|
||||
addLibrary(ui->m_libraries_label, "pugixml", "https://pugixml.org");
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::setLicence
|
||||
*/
|
||||
void AboutQETDialog::setLicence()
|
||||
{
|
||||
ui->m_license_text_edit->setPlainText(QET::license());
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::addAuthor
|
||||
Adds a person to the list of authors
|
||||
@param label : QLabel which will add the person
|
||||
@param name : Name of person
|
||||
@param email : E-mail address of the person
|
||||
@param work : Function / work done by the person
|
||||
*/
|
||||
* @brief AboutQETDialog::addAuthor
|
||||
* Adds a person to the list of authors
|
||||
* @param label : QLabel which will add the person
|
||||
* @param name : Name of person
|
||||
* @param email : E-mail address of the person
|
||||
* @param work : Function / work done by the person
|
||||
*/
|
||||
void AboutQETDialog::addAuthor(QLabel *label, const QString &name, const QString &email, const QString &work)
|
||||
{
|
||||
QString new_text = label->text();
|
||||
@@ -259,12 +180,6 @@ void AboutQETDialog::addAuthor(QLabel *label, const QString &name, const QString
|
||||
label->setText(new_text);
|
||||
}
|
||||
|
||||
/**
|
||||
@brief AboutQETDialog::addLibrary
|
||||
@param label
|
||||
@param name
|
||||
@param link
|
||||
*/
|
||||
void AboutQETDialog::addLibrary(QLabel *label, const QString &name, const QString &link)
|
||||
{
|
||||
QString new_text = label->text();
|
||||
|
||||
@@ -26,9 +26,6 @@ namespace Ui {
|
||||
class AboutQETDialog;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief The AboutQETDialog class
|
||||
*/
|
||||
class AboutQETDialog : public QDialog
|
||||
{
|
||||
Q_OBJECT
|
||||
@@ -45,13 +42,8 @@ class AboutQETDialog : public QDialog
|
||||
void setVersion();
|
||||
void setLibraries();
|
||||
void setLicence();
|
||||
void addAuthor(QLabel *label,
|
||||
const QString &name,
|
||||
const QString &email,
|
||||
const QString &work);
|
||||
void addLibrary(QLabel *label,
|
||||
const QString &name,
|
||||
const QString &link);
|
||||
void addAuthor(QLabel *label, const QString &name, const QString &email, const QString &work);
|
||||
void addLibrary(QLabel *label, const QString &name, const QString &link);
|
||||
|
||||
private:
|
||||
Ui::AboutQETDialog *ui;
|
||||
|
||||
@@ -61,7 +61,6 @@ BOMExportDialog::BOMExportDialog(QETProject *project, QWidget *parent) :
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 15, 0) // ### Qt 6: remove
|
||||
connect(&m_button_group, static_cast<void (QButtonGroup::*)(int)>(&QButtonGroup::buttonClicked), [this](int id)
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.15 or later")
|
||||
connect(&m_button_group, static_cast<void (QButtonGroup::*)(int)>(&QButtonGroup::idClicked), [this](int id)
|
||||
#endif
|
||||
{
|
||||
@@ -155,7 +154,6 @@ int BOMExportDialog::exec()
|
||||
#if QT_VERSION < QT_VERSION_CHECK(5, 15, 0) // ### Qt 6: remove
|
||||
stream << getBom() << endl;
|
||||
#else
|
||||
#pragma message("@TODO remove code for QT 5.15 or later")
|
||||
stream << getBom() << &Qt::endl(stream);
|
||||
#endif
|
||||
}
|
||||
|
||||
@@ -16,7 +16,6 @@ CompositeTextEditDialog::CompositeTextEditDialog(DynamicElementTextItem *text, Q
|
||||
m_default_text = m_text->compositeText();
|
||||
ui->m_plain_text_edit->setPlainText(m_default_text);
|
||||
#if QT_VERSION >= 0x050300
|
||||
#pragma message("@TODO remove code for QT 5.3 or later")
|
||||
ui->m_plain_text_edit->setPlaceholderText(tr("Entrée votre texte composé ici, en vous aidant des variables disponible"));
|
||||
#endif
|
||||
setUpComboBox();
|
||||
@@ -30,7 +29,6 @@ CompositeTextEditDialog::CompositeTextEditDialog(QString text, QWidget *parent)
|
||||
m_default_text = std::move(text);
|
||||
ui->m_plain_text_edit->setPlainText(m_default_text);
|
||||
#if QT_VERSION >= 0x050300
|
||||
#pragma message("@TODO remove code for QT 5.3 or later")
|
||||
ui->m_plain_text_edit->setPlaceholderText(tr("Entrée votre texte composé ici, en vous aidant des variables disponible"));
|
||||
#endif
|
||||
setUpComboBox();
|
||||
|
||||
@@ -186,6 +186,10 @@ QUndoCommand *DynamicElementTextItemEditor::associatedUndo() const
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief DynamicElementTextItemEditor::dataEdited
|
||||
* Apply changes to the text item. It is called when dataChanged() signal is called
|
||||
*/
|
||||
void DynamicElementTextItemEditor::dataEdited()
|
||||
{
|
||||
if (m_live_edit)
|
||||
|
||||
@@ -29,6 +29,10 @@ namespace Ui {
|
||||
class DynamicElementTextItemEditor;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief The DynamicElementTextItemEditor class
|
||||
* Widget used to modify the properties of DynamicElementTextItem.
|
||||
*/
|
||||
class DynamicElementTextItemEditor : public AbstractElementPropertiesEditorWidget
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
@@ -57,6 +57,10 @@ static int adjust_grp_row = 4;
|
||||
static int frame_grp_row = 5;
|
||||
static int hold_to_bottom_grp_row = 6;
|
||||
|
||||
const char* user_text = "Texte utilisateur";
|
||||
const char* element_information = "Information de l'élément";
|
||||
const char* composite_text = "Texte composé";
|
||||
|
||||
DynamicElementTextModel::DynamicElementTextModel(Element *element, QObject *parent) :
|
||||
QStandardItemModel(parent),
|
||||
m_element(element)
|
||||
@@ -136,9 +140,9 @@ QList<QStandardItem *> DynamicElementTextModel::itemsForText(DynamicElementTextI
|
||||
src->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
|
||||
|
||||
QString title;
|
||||
if (deti->textFrom() == DynamicElementTextItem::UserText) title = tr("Texte utilisateur");
|
||||
else if (deti->textFrom() == DynamicElementTextItem::ElementInfo) title = tr("Information de l'élément");
|
||||
else title = tr("Texte composé");
|
||||
if (deti->textFrom() == DynamicElementTextItem::UserText) title = tr(user_text);
|
||||
else if (deti->textFrom() == DynamicElementTextItem::ElementInfo) title = tr(element_information);
|
||||
else title = tr(composite_text);
|
||||
QStandardItem *srca = new QStandardItem(title);
|
||||
srca->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable);
|
||||
srca->setData(textFrom, Qt::UserRole+1);
|
||||
@@ -172,7 +176,7 @@ QList<QStandardItem *> DynamicElementTextModel::itemsForText(DynamicElementTextI
|
||||
qsi->appendRow(qsi_list);
|
||||
|
||||
//Composite text
|
||||
QStandardItem *composite = new QStandardItem(tr("Texte composé"));
|
||||
QStandardItem *composite = new QStandardItem(tr(composite_text));
|
||||
composite->setFlags(Qt::ItemIsSelectable | Qt::ItemIsEnabled);
|
||||
|
||||
DiagramContext dc;
|
||||
@@ -397,7 +401,7 @@ DynamicElementTextItem *DynamicElementTextModel::textFromItem(QStandardItem *ite
|
||||
|
||||
|
||||
QStandardItem *text_item = item;
|
||||
while (text_item->parent())
|
||||
while (text_item->parent()) // recursive search for the highest parent
|
||||
text_item = text_item->parent();
|
||||
|
||||
if (m_texts_list.values().contains(text_item)) //The item is a text
|
||||
@@ -458,26 +462,26 @@ QUndoCommand *DynamicElementTextModel::undoForEditedText(DynamicElementTextItem
|
||||
QStandardItem *text_qsi = m_texts_list.value(deti);
|
||||
|
||||
QString from = text_qsi->child(src_txt_row,1)->data(Qt::DisplayRole).toString();
|
||||
if ((from == tr("Texte utilisateur")) && (deti->textFrom() != DynamicElementTextItem::UserText))
|
||||
if ((from == tr(user_text)) && (deti->textFrom() != DynamicElementTextItem::UserText))
|
||||
new QPropertyUndoCommand(deti, "textFrom", QVariant(deti->textFrom()), QVariant(DynamicElementTextItem::UserText), undo);
|
||||
else if ((from == tr("Information de l'élément")) && (deti->textFrom() != DynamicElementTextItem::ElementInfo))
|
||||
else if ((from == tr(element_information)) && (deti->textFrom() != DynamicElementTextItem::ElementInfo))
|
||||
new QPropertyUndoCommand(deti, "textFrom", QVariant(deti->textFrom()), QVariant(DynamicElementTextItem::ElementInfo), undo);
|
||||
else if ((from == tr("Texte composé")) && (deti->textFrom() != DynamicElementTextItem::CompositeText))
|
||||
else if ((from == tr(composite_text)) && (deti->textFrom() != DynamicElementTextItem::CompositeText))
|
||||
new QPropertyUndoCommand(deti, "textFrom", QVariant(deti->textFrom()), QVariant(DynamicElementTextItem::CompositeText), undo);
|
||||
|
||||
if(from == tr("Texte utilisateur"))
|
||||
if(from == tr(user_text))
|
||||
{
|
||||
QString text = text_qsi->child(usr_txt_row,1)->data(Qt::DisplayRole).toString();
|
||||
if (text != deti->text())
|
||||
new QPropertyUndoCommand(deti, "text", QVariant(deti->text()), QVariant(text), undo);
|
||||
}
|
||||
else if (from == tr("Information de l'élément"))
|
||||
else if (from == tr(element_information))
|
||||
{
|
||||
QString info_name = text_qsi->child(info_txt_row,1)->data(Qt::UserRole+2).toString();
|
||||
if(info_name != deti->infoName())
|
||||
new QPropertyUndoCommand(deti, "infoName", QVariant(deti->infoName()), QVariant(info_name), undo);
|
||||
}
|
||||
else if (from == tr("Texte composé"))
|
||||
else if (from == tr(composite_text))
|
||||
{
|
||||
QString composite_text = text_qsi->child(compo_txt_row,1)->data(Qt::UserRole+2).toString();
|
||||
if(composite_text != deti->compositeText())
|
||||
@@ -1112,6 +1116,7 @@ void DynamicElementTextModel::enableSourceText(DynamicElementTextItem *deti, Dyn
|
||||
case DynamicElementTextItem::CompositeText: compo = true;break;
|
||||
}
|
||||
|
||||
m_ignore_item_change = true;
|
||||
//User text
|
||||
qsi->child(usr_txt_row,0)->setEnabled(usr);
|
||||
qsi->child(usr_txt_row,1)->setEnabled(usr);
|
||||
@@ -1120,6 +1125,7 @@ void DynamicElementTextModel::enableSourceText(DynamicElementTextItem *deti, Dyn
|
||||
qsi->child(info_txt_row,1)->setEnabled(info);
|
||||
//Composite text
|
||||
qsi->child(compo_txt_row,0)->setEnabled(compo);
|
||||
m_ignore_item_change = false;
|
||||
qsi->child(compo_txt_row,1)->setEnabled(compo);
|
||||
}
|
||||
|
||||
@@ -1157,6 +1163,10 @@ void DynamicElementTextModel::enableGroupRotationAndPos(ElementTextItemGroup *gr
|
||||
|
||||
void DynamicElementTextModel::itemDataChanged(QStandardItem *qsi)
|
||||
{
|
||||
|
||||
if (m_ignore_item_change)
|
||||
return;
|
||||
|
||||
DynamicElementTextItem *deti = textFromItem(qsi);
|
||||
ElementTextItemGroup *etig = groupFromItem(qsi);
|
||||
if (!deti && !etig)
|
||||
@@ -1170,15 +1180,15 @@ void DynamicElementTextModel::itemDataChanged(QStandardItem *qsi)
|
||||
dc = deti->elementUseForInfo()->elementInformations();
|
||||
|
||||
if (qsi->data().toInt() == textFrom)
|
||||
{
|
||||
{ // change textFrom
|
||||
QString from = qsi->data(Qt::DisplayRole).toString();
|
||||
|
||||
if (from == tr("Texte utilisateur"))
|
||||
if (from == tr(user_text))
|
||||
{
|
||||
enableSourceText(deti, DynamicElementTextItem::UserText);
|
||||
text_qsi->setData(text_qsi->child(usr_txt_row,1)->data(Qt::DisplayRole).toString());
|
||||
}
|
||||
else if (from == tr("Information de l'élément"))
|
||||
else if (from == tr(element_information))
|
||||
{
|
||||
enableSourceText(deti, DynamicElementTextItem::ElementInfo);
|
||||
QString info = text_qsi->child(info_txt_row,1)->data(Qt::UserRole+2).toString();
|
||||
@@ -1213,7 +1223,7 @@ void DynamicElementTextModel::itemDataChanged(QStandardItem *qsi)
|
||||
//We emit the signal only if @qsi is in the second column, because the data are stored on this column
|
||||
//the first column is use only for display the title of the property, except for the name of texts group
|
||||
if((m_groups_list.values().contains(qsi) || qsi->column() == 1) && !m_block_dataChanged)
|
||||
emit dataChanged();
|
||||
emit dataChanged(); // TODO: where it goes?
|
||||
if(deti) deti->updateXref();
|
||||
}
|
||||
|
||||
@@ -1309,9 +1319,9 @@ void DynamicElementTextModel::updateDataFromText(DynamicElementTextItem *deti, V
|
||||
{
|
||||
switch (deti->textFrom())
|
||||
{
|
||||
case DynamicElementTextItem::UserText: qsi->child(0,1)->setData(tr("Texte utilisateur"), Qt::DisplayRole); break;
|
||||
case DynamicElementTextItem::ElementInfo : qsi->child(0,1)->setData(tr("Information de l'élément"), Qt::DisplayRole); break;
|
||||
case DynamicElementTextItem::CompositeText : qsi->child(0,1)->setData(tr("Texte composé"), Qt::DisplayRole); break;
|
||||
case DynamicElementTextItem::UserText: qsi->child(0,1)->setData(tr(user_text), Qt::DisplayRole); break;
|
||||
case DynamicElementTextItem::ElementInfo : qsi->child(0,1)->setData(tr(element_information), Qt::DisplayRole); break;
|
||||
case DynamicElementTextItem::CompositeText : qsi->child(0,1)->setData(tr(composite_text), Qt::DisplayRole); break;
|
||||
}
|
||||
enableSourceText(deti, deti->textFrom());
|
||||
qsi->setData(deti->toPlainText(), Qt::DisplayRole);
|
||||
@@ -1448,6 +1458,15 @@ DynamicTextItemDelegate::DynamicTextItemDelegate(QObject *parent) :
|
||||
QStyledItemDelegate(parent)
|
||||
{}
|
||||
|
||||
/*!
|
||||
* \brief DynamicTextItemDelegate::createEditor
|
||||
* Different widgets are used depending of the data which should be shown in the view.
|
||||
* For example for choosing color, a color chooser is used.
|
||||
* \param parent
|
||||
* \param option
|
||||
* \param index
|
||||
* \return
|
||||
*/
|
||||
QWidget *DynamicTextItemDelegate::createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const
|
||||
{
|
||||
switch (index.data(Qt::UserRole+1).toInt())
|
||||
@@ -1456,9 +1475,9 @@ QWidget *DynamicTextItemDelegate::createEditor(QWidget *parent, const QStyleOpti
|
||||
{
|
||||
QComboBox *qcb = new QComboBox(parent);
|
||||
qcb->setObjectName("text_from");
|
||||
qcb->addItem(tr("Texte utilisateur"));
|
||||
qcb->addItem(tr("Information de l'élément"));
|
||||
qcb->addItem(tr("Texte composé"));
|
||||
qcb->addItem(tr(user_text));
|
||||
qcb->addItem(tr(element_information));
|
||||
qcb->addItem(tr(composite_text));
|
||||
return qcb;
|
||||
}
|
||||
case DynamicElementTextModel::infoText:
|
||||
|
||||
@@ -106,6 +106,7 @@ class DynamicElementTextModel : public QStandardItemModel
|
||||
QHash <DynamicElementTextItem *, QList<QMetaObject::Connection>> m_hash_text_connect;
|
||||
QHash <ElementTextItemGroup *, QList<QMetaObject::Connection>> m_hash_group_connect;
|
||||
bool m_block_dataChanged = false;
|
||||
bool m_ignore_item_change{false};
|
||||
};
|
||||
|
||||
class DynamicTextItemDelegate : public QStyledItemDelegate
|
||||
|
||||
@@ -25,11 +25,11 @@
|
||||
#include <linkelementcommand.h>
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::MasterPropertiesWidget
|
||||
Default constructor
|
||||
@param elmt
|
||||
@param parent
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::MasterPropertiesWidget
|
||||
* Default constructor
|
||||
* @param elmt
|
||||
* @param parent
|
||||
*/
|
||||
MasterPropertiesWidget::MasterPropertiesWidget(Element *elmt, QWidget *parent) :
|
||||
AbstractElementPropertiesEditorWidget(parent),
|
||||
ui(new Ui::MasterPropertiesWidget),
|
||||
@@ -43,16 +43,10 @@ MasterPropertiesWidget::MasterPropertiesWidget(Element *elmt, QWidget *parent) :
|
||||
QStringList list;
|
||||
QSettings settings;
|
||||
if (settings.value("genericpanel/folio", false).toBool()) {
|
||||
list << tr("Vignette")
|
||||
<< tr("Label de folio")
|
||||
<< tr("Titre de folio")
|
||||
<< tr("Position");
|
||||
list << tr("Vignette") << tr("Label de folio") << tr("Titre de folio") << tr("Position");
|
||||
}
|
||||
else {
|
||||
list << tr("Vignette")
|
||||
<< tr("N° de folio")
|
||||
<< tr("Titre de folio")
|
||||
<< tr("Position");
|
||||
list << tr("Vignette") << tr("N° de folio") << tr("Titre de folio") << tr("Position");
|
||||
}
|
||||
ui->m_free_tree_widget->setHeaderLabels(list);
|
||||
ui->m_link_tree_widget->setHeaderLabels(list);
|
||||
@@ -64,22 +58,15 @@ MasterPropertiesWidget::MasterPropertiesWidget(Element *elmt, QWidget *parent) :
|
||||
m_show_element = new QAction(tr("Montrer l'élément maître"), this);
|
||||
m_save_header_state = new QAction(tr("Enregistrer la disposition"), this);
|
||||
|
||||
connect(ui->m_free_tree_widget, &QTreeWidget::itemDoubleClicked,
|
||||
this, &MasterPropertiesWidget::showElementFromTWI);
|
||||
connect(ui->m_link_tree_widget, &QTreeWidget::itemDoubleClicked,
|
||||
this, &MasterPropertiesWidget::showElementFromTWI);
|
||||
connect(ui->m_free_tree_widget, &QTreeWidget::itemDoubleClicked, this, &MasterPropertiesWidget::showElementFromTWI);
|
||||
connect(ui->m_link_tree_widget, &QTreeWidget::itemDoubleClicked, this, &MasterPropertiesWidget::showElementFromTWI);
|
||||
|
||||
connect(ui->m_free_tree_widget, &QTreeWidget::customContextMenuRequested,
|
||||
[this](QPoint point) {this->customContextMenu(point, 1);});
|
||||
connect(ui->m_link_tree_widget, &QTreeWidget::customContextMenuRequested,
|
||||
[this](QPoint point) {this->customContextMenu(point, 2);});
|
||||
connect(ui->m_free_tree_widget, &QTreeWidget::customContextMenuRequested, [this](QPoint point) {this->customContextMenu(point, 1);});
|
||||
connect(ui->m_link_tree_widget, &QTreeWidget::customContextMenuRequested, [this](QPoint point) {this->customContextMenu(point, 2);});
|
||||
|
||||
connect(m_link_action, &QAction::triggered,
|
||||
this, &MasterPropertiesWidget::on_link_button_clicked);
|
||||
connect(m_unlink_action, &QAction::triggered,
|
||||
this, &MasterPropertiesWidget::on_unlink_button_clicked);
|
||||
connect(m_show_qtwi, &QAction::triggered,
|
||||
[this]() {this->showElementFromTWI(this->m_qtwi_at_context_menu,0);});
|
||||
connect(m_link_action, &QAction::triggered, this, &MasterPropertiesWidget::on_link_button_clicked);
|
||||
connect(m_unlink_action, &QAction::triggered, this, &MasterPropertiesWidget::on_unlink_button_clicked);
|
||||
connect(m_show_qtwi, &QAction::triggered, [this]() {this->showElementFromTWI(this->m_qtwi_at_context_menu,0);});
|
||||
|
||||
connect(m_show_element, &QAction::triggered, [this]()
|
||||
{
|
||||
@@ -91,8 +78,7 @@ MasterPropertiesWidget::MasterPropertiesWidget(Element *elmt, QWidget *parent) :
|
||||
|
||||
QHeaderView *qhv = ui->m_free_tree_widget->header();
|
||||
qhv->setContextMenuPolicy(Qt::CustomContextMenu);
|
||||
connect(qhv, &QHeaderView::customContextMenuRequested,
|
||||
this, &MasterPropertiesWidget::headerCustomContextMenuRequested);
|
||||
connect(qhv, &QHeaderView::customContextMenuRequested, this, &MasterPropertiesWidget::headerCustomContextMenuRequested);
|
||||
connect(m_save_header_state, &QAction::triggered, [qhv]()
|
||||
{
|
||||
QByteArray qba = qhv->saveState();
|
||||
@@ -104,9 +90,9 @@ MasterPropertiesWidget::MasterPropertiesWidget(Element *elmt, QWidget *parent) :
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::~MasterPropertiesWidget
|
||||
Destructor
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::~MasterPropertiesWidget
|
||||
* Destructor
|
||||
*/
|
||||
MasterPropertiesWidget::~MasterPropertiesWidget()
|
||||
{
|
||||
if (m_showed_element)
|
||||
@@ -119,10 +105,10 @@ MasterPropertiesWidget::~MasterPropertiesWidget()
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::setElement
|
||||
Set the element to be edited
|
||||
@param element
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::setElement
|
||||
* Set the element to be edited
|
||||
* @param element
|
||||
*/
|
||||
void MasterPropertiesWidget::setElement(Element *element)
|
||||
{
|
||||
if (m_element == element)
|
||||
@@ -137,37 +123,32 @@ void MasterPropertiesWidget::setElement(Element *element)
|
||||
m_element->setHighlighted(false);
|
||||
|
||||
if (m_project)
|
||||
disconnect(m_project, SIGNAL(diagramRemoved(QETProject*,Diagram*)),
|
||||
this, SLOT(diagramWasdeletedFromProject()));
|
||||
disconnect(m_project, SIGNAL(diagramRemoved(QETProject*,Diagram*)), this, SLOT(diagramWasdeletedFromProject()));
|
||||
|
||||
if(Q_LIKELY(element->diagram() && element->diagram()->project()))
|
||||
{
|
||||
m_project = element->diagram()->project();
|
||||
connect(m_project, SIGNAL(diagramRemoved(QETProject*,Diagram*)),
|
||||
this, SLOT(diagramWasdeletedFromProject()));
|
||||
connect(m_project, SIGNAL(diagramRemoved(QETProject*,Diagram*)), this, SLOT(diagramWasdeletedFromProject()));
|
||||
}
|
||||
else
|
||||
m_project = nullptr;
|
||||
|
||||
//Keep up to date this widget when the linked elements of m_element change
|
||||
//Keep up to date this widget when the linked elements of m_element change
|
||||
if (m_element)
|
||||
disconnect(m_element.data(), &Element::linkedElementChanged,
|
||||
this, &MasterPropertiesWidget::updateUi);
|
||||
disconnect(m_element.data(), &Element::linkedElementChanged, this, &MasterPropertiesWidget::updateUi);
|
||||
|
||||
m_element = element;
|
||||
connect(m_element.data(), &Element::linkedElementChanged,
|
||||
this, &MasterPropertiesWidget::updateUi);
|
||||
connect(m_element.data(), &Element::linkedElementChanged, this, &MasterPropertiesWidget::updateUi);
|
||||
|
||||
updateUi();
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::apply
|
||||
If link betwen edited element and other change,
|
||||
apply the change with a QUndoCommand (got with method associatedUndo)
|
||||
pushed to the stack of element project.
|
||||
Return true if link change, else false
|
||||
@note is void no Return ???
|
||||
* @brief MasterPropertiesWidget::apply
|
||||
* If link betwen edited element and other change,
|
||||
* apply the change with a QUndoCommand (got with method associatedUndo)
|
||||
* pushed to the stack of element project.
|
||||
* Return true if link change, else false
|
||||
*/
|
||||
void MasterPropertiesWidget::apply() {
|
||||
if (QUndoCommand *undo = associatedUndo())
|
||||
@@ -175,9 +156,9 @@ void MasterPropertiesWidget::apply() {
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::reset
|
||||
Reset curent widget, clear eveything and rebuild widget.
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::reset
|
||||
* Reset curent widget, clear eveything and rebuild widget.
|
||||
*/
|
||||
void MasterPropertiesWidget::reset()
|
||||
{
|
||||
foreach (QTreeWidgetItem *qtwi, m_qtwi_hash.keys())
|
||||
@@ -188,12 +169,12 @@ void MasterPropertiesWidget::reset()
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::associatedUndo
|
||||
If link between the edited element and other change,
|
||||
return a QUndoCommand with this change.
|
||||
If no change return nullptr.
|
||||
@return
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::associatedUndo
|
||||
* If link between the edited element and other change,
|
||||
* return a QUndoCommand with this change.
|
||||
* If no change return nullptr.
|
||||
* @return
|
||||
*/
|
||||
QUndoCommand* MasterPropertiesWidget::associatedUndo() const
|
||||
{
|
||||
QList <Element *> to_link;
|
||||
@@ -226,11 +207,11 @@ QUndoCommand* MasterPropertiesWidget::associatedUndo() const
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::setLiveEdit
|
||||
@param live_edit = true : live edit is enable
|
||||
else false : live edit is disable.
|
||||
@return always true because live edit is handled by this editor widget
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::setLiveEdit
|
||||
* @param live_edit = true : live edit is enable
|
||||
* else false : live edit is disable.
|
||||
* @return always true because live edit is handled by this editor widget
|
||||
*/
|
||||
bool MasterPropertiesWidget::setLiveEdit(bool live_edit)
|
||||
{
|
||||
m_live_edit = live_edit;
|
||||
@@ -238,9 +219,9 @@ bool MasterPropertiesWidget::setLiveEdit(bool live_edit)
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::updateUi
|
||||
Build the interface of the widget
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::updateUi
|
||||
* Build the interface of the widget
|
||||
*/
|
||||
void MasterPropertiesWidget::updateUi()
|
||||
{
|
||||
ui->m_free_tree_widget->clear();
|
||||
@@ -264,24 +245,17 @@ void MasterPropertiesWidget::updateUi()
|
||||
if(settings.value("genericpanel/folio", false).toBool())
|
||||
{
|
||||
autonum::sequentialNumbers seq;
|
||||
QString F =autonum::AssignVariables::formulaToLabel(
|
||||
elmt->diagram()->border_and_titleblock.folio(),
|
||||
seq,
|
||||
elmt->diagram(),
|
||||
elmt);
|
||||
QString F =autonum::AssignVariables::formulaToLabel(elmt->diagram()->border_and_titleblock.folio(), seq, elmt->diagram(), elmt);
|
||||
qtwi->setText(1, F);
|
||||
}
|
||||
else
|
||||
{
|
||||
qtwi->setText(1, QString::number(
|
||||
elmt->diagram()->folioIndex()
|
||||
+ 1));
|
||||
qtwi->setText(1, QString::number(elmt->diagram()->folioIndex() + 1));
|
||||
}
|
||||
|
||||
|
||||
qtwi->setText(2, elmt->diagram()->title());
|
||||
qtwi->setText(4, elmt->diagram()->convertPosition(
|
||||
elmt->scenePos()).toString());
|
||||
qtwi->setText(4, elmt->diagram()->convertPosition(elmt->scenePos()).toString());
|
||||
items_list.append(qtwi);
|
||||
m_qtwi_hash.insert(qtwi, elmt);
|
||||
}
|
||||
@@ -299,23 +273,16 @@ void MasterPropertiesWidget::updateUi()
|
||||
if(settings.value("genericpanel/folio", false).toBool())
|
||||
{
|
||||
autonum::sequentialNumbers seq;
|
||||
QString F =autonum::AssignVariables::formulaToLabel(
|
||||
elmt->diagram()->border_and_titleblock.folio(),
|
||||
seq,
|
||||
elmt->diagram(),
|
||||
elmt);
|
||||
QString F =autonum::AssignVariables::formulaToLabel(elmt->diagram()->border_and_titleblock.folio(), seq, elmt->diagram(), elmt);
|
||||
qtwi->setText(1, F);
|
||||
}
|
||||
else
|
||||
{
|
||||
qtwi->setText(1, QString::number(
|
||||
elmt->diagram()->folioIndex()
|
||||
+ 1));
|
||||
qtwi->setText(1, QString::number(elmt->diagram()->folioIndex() + 1));
|
||||
}
|
||||
|
||||
qtwi->setText(2, elmt->diagram()->title());
|
||||
qtwi->setText(3, elmt->diagram()->convertPosition(
|
||||
elmt->scenePos()).toString());
|
||||
qtwi->setText(3, elmt->diagram()->convertPosition(elmt->scenePos()).toString());
|
||||
items_list.append(qtwi);
|
||||
m_qtwi_hash.insert(qtwi, elmt);
|
||||
}
|
||||
@@ -331,10 +298,6 @@ void MasterPropertiesWidget::updateUi()
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::headerCustomContextMenuRequested
|
||||
@param pos
|
||||
*/
|
||||
void MasterPropertiesWidget::headerCustomContextMenuRequested(const QPoint &pos)
|
||||
{
|
||||
m_context_menu->clear();
|
||||
@@ -343,17 +306,16 @@ void MasterPropertiesWidget::headerCustomContextMenuRequested(const QPoint &pos)
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::on_link_button_clicked
|
||||
move curent item in the free_list to linked_list
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::on_link_button_clicked
|
||||
* move curent item in the free_list to linked_list
|
||||
*/
|
||||
void MasterPropertiesWidget::on_link_button_clicked()
|
||||
{
|
||||
//take the curent item from free_list and push it to linked_list
|
||||
QTreeWidgetItem *qtwi = ui->m_free_tree_widget->currentItem();
|
||||
if (qtwi)
|
||||
{
|
||||
ui->m_free_tree_widget->takeTopLevelItem(
|
||||
ui->m_free_tree_widget->indexOfTopLevelItem(qtwi));
|
||||
ui->m_free_tree_widget->takeTopLevelItem(ui->m_free_tree_widget->indexOfTopLevelItem(qtwi));
|
||||
ui->m_link_tree_widget->insertTopLevelItem(0, qtwi);
|
||||
|
||||
if(m_live_edit)
|
||||
@@ -362,17 +324,16 @@ void MasterPropertiesWidget::on_link_button_clicked()
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::on_unlink_button_clicked
|
||||
move curent item in linked_list to free_list
|
||||
*/
|
||||
* @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
|
||||
QTreeWidgetItem *qtwi = ui->m_link_tree_widget->currentItem();
|
||||
if(qtwi)
|
||||
{
|
||||
ui->m_link_tree_widget->takeTopLevelItem(
|
||||
ui->m_link_tree_widget->indexOfTopLevelItem(qtwi));
|
||||
ui->m_link_tree_widget->takeTopLevelItem(ui->m_link_tree_widget->indexOfTopLevelItem(qtwi));
|
||||
ui->m_free_tree_widget->insertTopLevelItem(0, qtwi);
|
||||
|
||||
if(m_live_edit)
|
||||
@@ -381,18 +342,17 @@ void MasterPropertiesWidget::on_unlink_button_clicked()
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::showElementFromTWI
|
||||
Show the element corresponding to the given QTreeWidgetItem
|
||||
@param qtwi
|
||||
@param column
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::showElementFromTWI
|
||||
* Show the element corresponding to the given QTreeWidgetItem
|
||||
* @param qtwi
|
||||
* @param column
|
||||
*/
|
||||
void MasterPropertiesWidget::showElementFromTWI(QTreeWidgetItem *qtwi, int column)
|
||||
{
|
||||
Q_UNUSED(column);
|
||||
if (m_showed_element)
|
||||
{
|
||||
disconnect(m_showed_element, SIGNAL(destroyed()),
|
||||
this, SLOT(showedElementWasDeleted()));
|
||||
disconnect(m_showed_element, SIGNAL(destroyed()), this, SLOT(showedElementWasDeleted()));
|
||||
m_showed_element -> setHighlighted(false);
|
||||
}
|
||||
if (m_element)
|
||||
@@ -401,44 +361,39 @@ void MasterPropertiesWidget::showElementFromTWI(QTreeWidgetItem *qtwi, int colum
|
||||
m_showed_element = m_qtwi_hash[qtwi];
|
||||
m_showed_element->diagram()->showMe();
|
||||
m_showed_element->setHighlighted(true);
|
||||
connect(m_showed_element, SIGNAL(destroyed()),
|
||||
this, SLOT(showedElementWasDeleted()));
|
||||
connect(m_showed_element, SIGNAL(destroyed()), this, SLOT(showedElementWasDeleted()));
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::showedElementWasDeleted
|
||||
Set to nullptr the current showed element when he was deleted
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::showedElementWasDeleted
|
||||
* Set to nullptr the current showed element when he was deleted
|
||||
*/
|
||||
void MasterPropertiesWidget::showedElementWasDeleted() {
|
||||
m_showed_element = nullptr;
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::diagramWasdeletedFromProject
|
||||
This slot is called when a diagram is removed from the parent project
|
||||
of edited element to update the content of this widget
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::diagramWasdeletedFromProject
|
||||
* This slot is called when a diagram is removed from the parent project of edited element
|
||||
* to update the content of this widget
|
||||
*/
|
||||
void MasterPropertiesWidget::diagramWasdeletedFromProject()
|
||||
{
|
||||
// We use a timer because if the removed diagram
|
||||
// contain slave element linked to the edited element
|
||||
// we must to wait for this elements be unlinked,
|
||||
// else the linked list provide deleted elements.
|
||||
//We use a timer because if the removed diagram contain slave element linked to the edited element
|
||||
//we must to wait for this elements be unlinked, else the linked list provide deleted elements.
|
||||
QTimer::singleShot(10, this, SLOT(updateUi()));
|
||||
}
|
||||
|
||||
/**
|
||||
@brief MasterPropertiesWidget::customContextMenu
|
||||
Display a context menu
|
||||
@param pos
|
||||
@param i : the tree widget where the context menu was requested.
|
||||
*/
|
||||
* @brief MasterPropertiesWidget::customContextMenu
|
||||
* Display a context menu
|
||||
* @param pos
|
||||
* @param i : the tree widget where the context menu was requested.
|
||||
*/
|
||||
void MasterPropertiesWidget::customContextMenu(const QPoint &pos, int i)
|
||||
{
|
||||
// add the size of the header to display the topleft of the QMenu
|
||||
// at the position of the mouse.
|
||||
// See doc about QWidget::customContextMenuRequested
|
||||
// section related to QAbstractScrollArea
|
||||
//add the size of the header to display the topleft of the QMenu at the position of the mouse.
|
||||
//See doc about QWidget::customContextMenuRequested section related to QAbstractScrollArea
|
||||
QPoint point = pos;
|
||||
point.ry()+=ui->m_free_tree_widget->header()->height();
|
||||
|
||||
|
||||
@@ -35,30 +35,24 @@ namespace Ui {
|
||||
}
|
||||
|
||||
/**
|
||||
@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.
|
||||
*/
|
||||
* @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 AbstractElementPropertiesEditorWidget
|
||||
{
|
||||
Q_OBJECT
|
||||
|
||||
public:
|
||||
explicit MasterPropertiesWidget(Element *elmt,
|
||||
QWidget *parent = nullptr);
|
||||
explicit MasterPropertiesWidget(Element *elmt, QWidget *parent = nullptr);
|
||||
~MasterPropertiesWidget() override;
|
||||
|
||||
void setElement (Element *element) override;
|
||||
void apply() override;
|
||||
void reset() override;
|
||||
QUndoCommand *associatedUndo () const override;
|
||||
/**
|
||||
* @brief title
|
||||
* @return QString title
|
||||
*/
|
||||
QString title() const override {
|
||||
return tr("Référence croisée (maître)");}
|
||||
QString title() const override {return tr("Référence croisée (maître)");}
|
||||
bool setLiveEdit(bool live_edit) override;
|
||||
|
||||
public slots:
|
||||
|
||||
@@ -77,7 +77,6 @@ m_diagram(diagram)
|
||||
#if QT_VERSION >= 0x050900
|
||||
else
|
||||
setObsolete(true);
|
||||
#pragma message("@TODO remove code for QT 5.9 or later")
|
||||
#endif
|
||||
|
||||
}
|
||||
@@ -136,7 +135,6 @@ void RotateTextsCommand::openDialog()
|
||||
#if QT_VERSION >= 0x050900
|
||||
else
|
||||
setObsolete(true);
|
||||
#pragma message("@TODO remove code for QT 5.9 or later")
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user