X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Ftopicwidget.cpp;h=336b902d128a8f4eb7bd4ede1d3496613798756c;hb=4e51500401db3c85dbe5e92e5e5c15b6e3c87787;hp=007072c790fcb276400875d70ea4c6129a4d29d3;hpb=2c8434f74c68194d56f2084f637419123e61d18b;p=quassel.git diff --git a/src/qtui/topicwidget.cpp b/src/qtui/topicwidget.cpp index 007072c7..336b902d 100644 --- a/src/qtui/topicwidget.cpp +++ b/src/qtui/topicwidget.cpp @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-2018 by the Quassel Project * + * Copyright (C) 2005-2020 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -21,14 +21,14 @@ #include "topicwidget.h" #include "client.h" +#include "graphicalui.h" #include "icon.h" #include "networkmodel.h" #include "uisettings.h" -#include "graphicalui.h" #include "uistyle.h" #include "util.h" -TopicWidget::TopicWidget(QWidget *parent) +TopicWidget::TopicWidget(QWidget* parent) : AbstractItemView(parent) { ui.setupUi(this); @@ -54,15 +54,13 @@ TopicWidget::TopicWidget(QWidget *parent) _readonly = false; } - -void TopicWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) +void TopicWidget::currentChanged(const QModelIndex& current, const QModelIndex& previous) { Q_UNUSED(previous); setTopic(current); } - -void TopicWidget::dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight) +void TopicWidget::dataChanged(const QModelIndex& topLeft, const QModelIndex& bottomRight) { QItemSelectionRange changedArea(topLeft, bottomRight); QModelIndex currentTopicIndex = selectionModel()->currentIndex().sibling(selectionModel()->currentIndex().row(), 1); @@ -70,7 +68,7 @@ void TopicWidget::dataChanged(const QModelIndex &topLeft, const QModelIndex &bot setTopic(selectionModel()->currentIndex()); } -void TopicWidget::setUseCustomFont(const QVariant &v) +void TopicWidget::setUseCustomFont(const QVariant& v) { if (v.toBool()) { UiStyleSettings fs("Fonts"); @@ -80,8 +78,7 @@ void TopicWidget::setUseCustomFont(const QVariant &v) setCustomFont(QFont()); } - -void TopicWidget::setCustomFont(const QVariant &v) +void TopicWidget::setCustomFont(const QVariant& v) { UiStyleSettings fs("Fonts"); if (!fs.value("UseCustomTopicWidgetFont", false).toBool()) @@ -90,8 +87,7 @@ void TopicWidget::setCustomFont(const QVariant &v) setCustomFont(v.value()); } - -void TopicWidget::setCustomFont(const QFont &f) +void TopicWidget::setCustomFont(const QFont& f) { QFont font = f; if (font.family().isEmpty()) @@ -101,8 +97,7 @@ void TopicWidget::setCustomFont(const QFont &f) ui.topicLabel->setCustomFont(font); } - -void TopicWidget::setTopic(const QModelIndex &index) +void TopicWidget::setTopic(const QModelIndex& index) { QString newtopic; bool readonly = true; @@ -110,16 +105,16 @@ void TopicWidget::setTopic(const QModelIndex &index) BufferId id = index.data(NetworkModel::BufferIdRole).value(); if (id.isValid()) { QModelIndex index0 = index.sibling(index.row(), 0); - const Network *network = Client::network(Client::networkModel()->networkId(id)); + const Network* network = Client::network(Client::networkModel()->networkId(id)); switch (Client::networkModel()->bufferType(id)) { case BufferInfo::StatusBuffer: if (network) { newtopic = QString("%1 (%2) | %3 | %4") - .arg(network->networkName().toHtmlEscaped()) - .arg(network->currentServer().toHtmlEscaped()) - .arg(tr("Users: %1").arg(network->ircUsers().count())) - .arg(tr("Lag: %1 msecs").arg(network->latency())); + .arg(network->networkName().toHtmlEscaped()) + .arg(network->currentServer().toHtmlEscaped()) + .arg(tr("Users: %1").arg(network->ircUsers().count())) + .arg(tr("Lag: %1 msecs").arg(network->latency())); } else { newtopic = index0.data(Qt::DisplayRole).toString(); @@ -131,23 +126,23 @@ void TopicWidget::setTopic(const QModelIndex &index) readonly = false; break; - case BufferInfo::QueryBuffer: - { + case BufferInfo::QueryBuffer: { QString nickname = index0.data(Qt::DisplayRole).toString(); if (network) { - const IrcUser *user = network->ircUser(nickname); + const IrcUser* user = network->ircUser(nickname); if (user) { - newtopic = QString("%1%2%3 | %4@%5").arg(nickname) - .arg(user->userModes().isEmpty() ? QString() : QString(" (+%1)").arg(user->userModes())) - .arg(user->realName().isEmpty() ? QString() : QString(" | %1").arg(user->realName())) - .arg(user->user()) - .arg(user->host()); + newtopic = QString("%1%2%3 | %4@%5") + .arg(nickname) + .arg(user->userModes().isEmpty() ? QString() : QString(" (+%1)").arg(user->userModes())) + .arg(user->realName().isEmpty() ? QString() : QString(" | %1").arg(user->realName())) + .arg(user->user()) + .arg(user->host()); } - else { // no such user + else { // no such user newtopic = nickname; } } - else { // no valid Network-Obj. + else { // no valid Network-Obj. newtopic = nickname; } break; @@ -157,17 +152,20 @@ void TopicWidget::setTopic(const QModelIndex &index) } } - _topic = sanitizeTopic(newtopic); - _readonly = readonly; + QString sanitizedNewTopic = sanitizeTopic(newtopic); + if (readonly != _readonly || sanitizedNewTopic != _topic) + { + _topic = sanitizedNewTopic; + _readonly = readonly; - ui.topicEditButton->setVisible(!_readonly); - ui.topicLabel->setText(_topic); - ui.topicLineEdit->setPlainText(_topic); - switchPlain(); + ui.topicEditButton->setVisible(!_readonly); + ui.topicLabel->setText(_topic); + ui.topicLineEdit->setPlainText(_topic); + switchPlain(); + } } - -void TopicWidget::setReadOnly(const bool &readonly) +void TopicWidget::setReadOnly(const bool& readonly) { if (_readonly == readonly) return; @@ -175,7 +173,6 @@ void TopicWidget::setReadOnly(const bool &readonly) _readonly = readonly; } - void TopicWidget::updateResizeMode() { StyledLabel::ResizeMode mode = StyledLabel::NoResize; @@ -190,15 +187,14 @@ void TopicWidget::updateResizeMode() ui.topicLabel->setResizeMode(mode); } - -void TopicWidget::clickableActivated(const Clickable &click) +void TopicWidget::clickableActivated(const Clickable& click) { NetworkId networkId = selectionModel()->currentIndex().data(NetworkModel::NetworkIdRole).value(); - UiStyle::StyledString sstr = GraphicalUi::uiStyle()->styleString(GraphicalUi::uiStyle()->mircToInternal(_topic), UiStyle::FormatType::PlainMsg); + UiStyle::StyledString sstr = GraphicalUi::uiStyle()->styleString(GraphicalUi::uiStyle()->mircToInternal(_topic), + UiStyle::FormatType::PlainMsg); click.activate(networkId, sstr.plainText); } - void TopicWidget::on_topicLineEdit_textEntered() { QModelIndex currentIdx = currentIndex(); @@ -212,13 +208,11 @@ void TopicWidget::on_topicLineEdit_textEntered() switchPlain(); } - void TopicWidget::on_topicEditButton_clicked() { switchEditable(); } - void TopicWidget::switchEditable() { ui.stackedWidget->setCurrentIndex(1); @@ -227,7 +221,6 @@ void TopicWidget::switchEditable() updateGeometry(); } - void TopicWidget::switchPlain() { ui.stackedWidget->setCurrentIndex(0); @@ -236,9 +229,8 @@ void TopicWidget::switchPlain() emit switchedPlain(); } - // filter for the input widget to switch back to normal mode -bool TopicWidget::eventFilter(QObject *obj, QEvent *event) +bool TopicWidget::eventFilter(QObject* obj, QEvent* event) { if (event->type() == QEvent::FocusOut && !_mouseEntered) { switchPlain(); @@ -256,7 +248,7 @@ bool TopicWidget::eventFilter(QObject *obj, QEvent *event) if (event->type() != QEvent::KeyRelease) return QObject::eventFilter(obj, event); - auto *keyEvent = static_cast(event); + auto* keyEvent = static_cast(event); if (keyEvent->key() == Qt::Key_Escape) { switchPlain();