/* 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 . */ #include "dynamictextfieldeditor.h" #include "ui_dynamictextfieldeditor.h" #include "customelementpart.h" #include "partdynamictextfield.h" #include "QPropertyUndoCommand/qpropertyundocommand.h" #include "qetelementeditor.h" #include "qetapp.h" #include "compositetexteditdialog.h" #include "alignmenttextdialog.h" #include "qetinformation.h" #include #include #include #include DynamicTextFieldEditor::DynamicTextFieldEditor( QETElementEditor *editor, PartDynamicTextField *text_field, QWidget *parent) : ElementItemEditor(editor, parent), ui(new Ui::DynamicTextFieldEditor) { ui -> setupUi(this); ui -> m_composite_text_pb -> setDisabled(true); ui -> m_elmt_info_cb -> setDisabled(true); if(text_field) { setPart(text_field); } } DynamicTextFieldEditor::~DynamicTextFieldEditor() { delete ui; if(!m_connection_list.isEmpty()) { for(const QMetaObject::Connection& con : m_connection_list) { disconnect(con); } } } /** @brief DynamicTextFieldEditor::setPart Set part as current edited part of this widget. @param part @return true if part can be edited by this widget */ bool DynamicTextFieldEditor::setPart(CustomElementPart *part) { disconnectConnections(); QGraphicsItem *qgi = part -> toItem(); if(!qgi) { return false; } else if (qgi -> type() != PartDynamicTextField::Type) { return false; } m_text_field = static_cast(qgi); updateForm(); setUpConnections(); fillInfoComboBox(); return true; } bool DynamicTextFieldEditor::setParts(QList parts) { if (parts.isEmpty()) { m_parts.clear(); if (m_text_field) { disconnectConnections(); } m_text_field = nullptr; return true; } if (PartDynamicTextField *part = static_cast(parts.first())) { if (m_text_field) { disconnectConnections(); } m_text_field = part; m_parts.clear(); m_parts.append(part); for (int i=1; i < parts.length(); i++) m_parts.append(static_cast(parts[i])); setUpConnections(); updateForm(); fillInfoComboBox(); return true; } return(false); } /** @brief DynamicTextFieldEditor::currentPart @return The current edited part, note they can return nullptr if there is not a currently edited part. */ CustomElementPart *DynamicTextFieldEditor::currentPart() const { return m_text_field.data(); } QList DynamicTextFieldEditor::currentParts() const { QList parts; for (auto part: m_parts) { parts.append(static_cast(part)); } return parts; } void DynamicTextFieldEditor::updateForm() { if(m_text_field) { ui -> m_x_sb -> setValue(m_text_field.data() -> x()); ui -> m_y_sb -> setValue(m_text_field.data() ->y ()); ui -> m_rotation_sb -> setValue(QET::correctAngle(m_text_field.data() -> rotation())); ui -> m_frame_cb -> setChecked(m_text_field.data() -> frame()); ui -> m_user_text_le -> setText(m_text_field.data() -> text()); ui -> m_size_sb -> setValue(m_text_field.data() -> font().pointSize()); ui -> m_color_kpb -> setColor(m_text_field.data() -> color()); ui -> m_width_sb -> setValue(m_text_field.data() -> textWidth()); ui -> m_font_pb -> setText(m_text_field -> font().family()); switch (m_text_field.data() -> textFrom()) { case DynamicElementTextItem::UserText: { ui -> m_text_from_cb -> setCurrentIndex(0); break; } case DynamicElementTextItem::ElementInfo: { ui -> m_text_from_cb -> setCurrentIndex(1); ui -> m_elmt_info_cb -> setCurrentIndex( ui -> m_elmt_info_cb -> findData(m_text_field.data() -> infoName())); break; } case DynamicElementTextItem::CompositeText: { ui -> m_text_from_cb -> setCurrentIndex(2); } } on_m_text_from_cb_activated(ui -> m_text_from_cb -> currentIndex()); //For enable the good widget } } void DynamicTextFieldEditor::setUpConnections() { assert(m_connection_list.isEmpty()); //Setup the connection m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::colorChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::fontChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::taggChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::textFromChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::textChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::infoNameChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::rotationChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::frameChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::textWidthChanged, [this](){this -> updateForm();}); m_connection_list << connect(m_text_field.data(), &PartDynamicTextField::compositeTextChanged, [this](){this -> updateForm();}); } void DynamicTextFieldEditor::disconnectConnections() { //Remove previous connection if(!m_connection_list.isEmpty()) for(const QMetaObject::Connection& con : m_connection_list) { disconnect(con); } m_connection_list.clear(); } /** @brief DynamicTextFieldEditor::fillInfoComboBox Fill the combo box "element information" */ void DynamicTextFieldEditor::fillInfoComboBox() { ui -> m_elmt_info_cb -> clear(); QStringList strl; QString type = elementEditor() -> elementScene() -> elementType(); if(type.contains("report")) { strl = QETInformation::folioReportInfoKeys(); } else { strl = QETInformation::elementInfoKeys(); } //We use a QMap because the keys of the map are sorted, then no matter the curent local, //the value of the combo box are always alphabetically sorted QMap info_map; for(const QString& str : strl) info_map.insert(QETInformation::translatedInfoKey(str), str); for (const QString& key : info_map.keys()) ui -> m_elmt_info_cb -> addItem(key, info_map.value(key)); } void DynamicTextFieldEditor::on_m_x_sb_editingFinished() { double value = ui -> m_x_sb -> value(); for (int i = 0; i < m_parts.length(); i++) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "x", m_parts[i] -> x(), value); undo -> setText(tr("Déplacer un champ texte")); undo -> enableAnimation(true); undoStack().push(undo); } } void DynamicTextFieldEditor::on_m_y_sb_editingFinished() { double value = ui -> m_y_sb -> value(); for (int i = 0; i < m_parts.length(); i++) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "y", m_parts[i] -> y(), value); undo -> setText(tr("Déplacer un champ texte")); undo -> enableAnimation(true); undoStack().push(undo); } } void DynamicTextFieldEditor::on_m_rotation_sb_editingFinished() { int value = ui -> m_rotation_sb -> value(); for (int i = 0; i < m_parts.length(); i++) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "rotation", m_parts[i] -> rotation(), value); undo -> setText(tr("Pivoter un champ texte")); undo -> enableAnimation(true); undoStack().push(undo); } } void DynamicTextFieldEditor::on_m_user_text_le_editingFinished() { QString text = ui -> m_user_text_le -> text(); for (int i = 0; i < m_parts.length(); i++) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "text", m_parts[i] -> text(), text); undo -> setText(tr("Modifier le texte d'un champ texte")); undoStack().push(undo); } } void DynamicTextFieldEditor::on_m_size_sb_editingFinished() { QFont font_ = m_text_field -> font(); font_.setPointSize(ui -> m_size_sb -> value()); for (int i = 0; i < m_parts.length(); i++) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "font", m_parts[i] -> font(), font_); undo -> setText(tr("Modifier la police d'un champ texte")); undoStack().push(undo); } } void DynamicTextFieldEditor::on_m_frame_cb_clicked() { bool frame = ui -> m_frame_cb -> isChecked(); for (int i = 0; i < m_parts.length(); i++) { if(frame != m_parts[i] -> frame()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "frame", m_parts[i] -> frame(), frame); undo -> setText(tr("Modifier le cadre d'un champ texte")); undoStack().push(undo); } } } void DynamicTextFieldEditor::on_m_width_sb_editingFinished() { qreal width = (qreal)ui -> m_width_sb -> value(); for (int i = 0; i < m_parts.length(); i++) { if(width != m_parts[i] -> textWidth()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "textWidth", m_parts[i] -> textWidth(), width); undo -> setText(tr("Modifier la largeur d'un texte")); undoStack().push(undo); } } } void DynamicTextFieldEditor::on_m_elmt_info_cb_activated(const QString &arg1) { Q_UNUSED(arg1) QString info = ui -> m_elmt_info_cb -> currentData().toString(); for (int i = 0; i < m_parts.length(); i++) { if(info != m_parts[i] -> infoName()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "infoName", m_parts[i] -> infoName(), info); undo->setText(tr("Modifier l'information d'un texte")); undoStack().push(undo); m_parts[i] -> setPlainText( elementEditor() -> elementScene() -> elementInformation().value(m_parts[i] -> infoName()).toString()); } } } void DynamicTextFieldEditor::on_m_text_from_cb_activated(int index) { ui -> m_user_text_le -> setDisabled(true); ui -> m_elmt_info_cb -> setDisabled(true); ui -> m_composite_text_pb -> setDisabled(true); if(index == 0) { ui->m_user_text_le->setEnabled(true); } else if (index == 1) { ui->m_elmt_info_cb->setEnabled(true); } else { ui->m_composite_text_pb->setEnabled(true); } DynamicElementTextItem::TextFrom tf; if(index == 0) { tf = DynamicElementTextItem::UserText; } else if(index == 1) { tf = DynamicElementTextItem::ElementInfo; } else { tf = DynamicElementTextItem::CompositeText; } for (int i = 0; i < m_parts.length(); i++) { if(tf != m_parts[i] -> textFrom()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "textFrom", m_parts[i] -> textFrom(), tf); undo -> setText(tr("Modifier la source de texte, d'un texte")); undoStack().push(undo); } } } void DynamicTextFieldEditor::on_m_composite_text_pb_clicked() { CompositeTextEditDialog ctd(m_text_field.data() -> compositeText(), this); if(ctd.exec()) { QString ct = ctd.plainText(); for (int i = 0; i < m_parts.length(); i++) { if(ct != m_parts[i] -> compositeText()) { QPropertyUndoCommand *undo =\ new QPropertyUndoCommand(m_parts[i], "compositeText", m_parts[i] -> compositeText(), ctd.plainText()); undoStack().push(undo); } } } } void DynamicTextFieldEditor::on_m_alignment_pb_clicked() { AlignmentTextDialog atd(m_text_field.data() -> alignment(), this); atd.exec(); for (int i = 0; i < m_parts.length(); i++) { if(atd.alignment() != m_parts[i] -> alignment()) { QPropertyUndoCommand *undo =\ new QPropertyUndoCommand( m_parts[i], "alignment", QVariant(m_parts[i] -> alignment()), QVariant(atd.alignment())); undo -> setText(tr("Modifier l'alignement d'un champ texte")); undoStack().push(undo); } } } void DynamicTextFieldEditor::on_m_font_pb_clicked() { bool ok; QFont font_ = QFontDialog::getFont(&ok, m_text_field -> font(), this); if (ok && font_ != this -> font()) { ui -> m_font_pb -> setText(font_.family()); ui -> m_size_sb -> setValue(font_.pointSize()); for (int i = 0; i < m_parts.length(); i++) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "font", m_parts[i] -> font(), font_); undo -> setText(tr("Modifier la police d'un champ texte")); undoStack().push(undo); } } } void DynamicTextFieldEditor::on_m_color_kpb_changed(const QColor &newColor) { if (!newColor.isValid()) { return; } for (int i = 0; i < m_parts.length(); i++) { if(newColor != m_parts[i] -> color()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_parts[i], "color", m_parts[i] -> color(), newColor); undo -> setText(tr("Modifier la couleur d'un champ texte")); undoStack().push(undo); } } }