/* Copyright 2006-2019 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 #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); fillInfoComboBox(); } 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) { //Remove previous connection if(!m_connection_list.isEmpty()) for(const QMetaObject::Connection& con : m_connection_list) disconnect(con); QGraphicsItem *qgi = part->toItem(); if(!qgi) return false; else if (qgi->type() != PartDynamicTextField::Type) return false; m_text_field = static_cast(qgi); updateForm(); //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();}); return true; } /** * @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(); } 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()); setColorPushButton(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::setColorPushButton(const QColor& color) { QPalette palette; palette.setColor(QPalette::Button, color); ui->m_color_pb->setStyleSheet(QString("background-color: %1; min-height: 1.5em; border-style: outset; border-width: 2px; border-color: gray; border-radius: 4px;").arg(color.name())); } /** * @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 << "function" << "tension-protocol"; else strl = QETApp::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(QETApp::elementTranslatedInfoKey(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() { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "x", m_text_field.data()->x(), ui->m_x_sb->value()); undo->setText(tr("Déplacer un champ texte")); undo->enableAnimation(true); undoStack().push(undo); } void DynamicTextFieldEditor::on_m_y_sb_editingFinished() { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "y", m_text_field.data()->y(), ui->m_y_sb->value()); undo->setText(tr("Déplacer un champ texte")); undo->enableAnimation(true); undoStack().push(undo); } void DynamicTextFieldEditor::on_m_rotation_sb_editingFinished() { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "rotation", m_text_field.data()->rotation(), ui->m_rotation_sb->value()); undo->setText(tr("Pivoter un champ texte")); undo->enableAnimation(true); undoStack().push(undo); } void DynamicTextFieldEditor::on_m_user_text_le_editingFinished() { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "text", m_text_field.data()->text(), ui->m_user_text_le->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()); QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "font", m_text_field.data()->font(), font_); undo->setText(tr("Modifier la police d'un champ texte")); undoStack().push(undo); } void DynamicTextFieldEditor::on_m_color_pb_clicked() { QColor color = QColorDialog::getColor(m_text_field.data()->color(), this, tr("Couleur du texte")); if(color.isValid() && color != m_text_field.data()->color()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "color", m_text_field.data()->color(), color); undo->setText(tr("Modifier la couleur d'un champ texte")); undoStack().push(undo); setColorPushButton(m_text_field.data()->color()); } } void DynamicTextFieldEditor::on_m_frame_cb_clicked() { bool frame = ui->m_frame_cb->isChecked(); if(frame != m_text_field.data()->frame()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "frame", m_text_field.data()->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(); if(width != m_text_field.data()->textWidth()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "textWidth", m_text_field.data()->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(); if(info != m_text_field.data()->infoName()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "infoName", m_text_field.data()->infoName(), info); undo->setText(tr("Modifier l'information d'un texte")); undoStack().push(undo); m_text_field.data()->setPlainText(elementEditor()->elementScene()->elementInformation().value(m_text_field.data()->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; if(tf != m_text_field.data()->textFrom()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field, "textFrom", m_text_field.data()->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(); if(ct != m_text_field.data()->compositeText()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field.data(), "compositeText", m_text_field.data()->compositeText(), ctd.plainText()); undoStack().push(undo); } } } void DynamicTextFieldEditor::on_m_alignment_pb_clicked() { AlignmentTextDialog atd(m_text_field.data()->alignment(), this); atd.exec(); if(atd.alignment() != m_text_field.data()->alignment()) { QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field.data(), "alignment", QVariant(m_text_field.data()->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()); QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_text_field.data(), "font", m_text_field->font(), font_); undo->setText(tr("Modifier la police d'un champ texte")); undoStack().push(undo); } }