X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fqtui%2Ftopicwidget.cpp;h=cb646eda090a06bd369a76d1b2d1dd513701df90;hb=8bf92d33ac84cfede11b2361832607bea98f64c8;hp=8adb0b6b46b3f4cba2ea5e0c222518fe5a400ef5;hpb=a23256347cc47605dd0660127052846427bc998d;p=quassel.git diff --git a/src/qtui/topicwidget.cpp b/src/qtui/topicwidget.cpp index 8adb0b6b..cb646eda 100644 --- a/src/qtui/topicwidget.cpp +++ b/src/qtui/topicwidget.cpp @@ -23,7 +23,7 @@ #include TopicWidget::TopicWidget(QWidget *parent) - : QWidget(parent) + : AbstractItemView(parent) { ui.setupUi(this); ui.topicLineEdit->hide(); @@ -31,15 +31,31 @@ TopicWidget::TopicWidget(QWidget *parent) ui.topicButton->show(); } +void TopicWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) { + Q_UNUSED(previous); + setTopic(current.sibling(current.row(), 1).data().toString()); +} + +void TopicWidget::dataChanged(const QModelIndex &topLeft, const QModelIndex &bottomRight) { + QItemSelectionRange changedArea(topLeft, bottomRight); + QModelIndex currentTopicIndex = selectionModel()->currentIndex().sibling(selectionModel()->currentIndex().row(), 1); + if(changedArea.contains(currentTopicIndex)) + setTopic(currentTopicIndex.data().toString()); +}; + void TopicWidget::setTopic(const QString &newtopic) { + if(_topic == newtopic) + return; + + _topic = newtopic; ui.topicButton->setAndStyleText(newtopic); ui.topicLineEdit->setText(newtopic); switchPlain(); } void TopicWidget::on_topicLineEdit_returnPressed() { + emit topicChanged(ui.topicLineEdit->text()); switchPlain(); - emit topicChanged(topic()); } void TopicWidget::on_topicButton_clicked() { @@ -49,14 +65,22 @@ void TopicWidget::on_topicButton_clicked() { void TopicWidget::switchEditable() { ui.topicButton->hide(); ui.topicLineEdit->show(); + ui.topicLineEdit->setFocus(); } void TopicWidget::switchPlain() { ui.topicLineEdit->hide(); ui.topicButton->show(); + ui.topicLineEdit->setText(_topic); } +// filter for the input widget to switch back to normal mode bool TopicWidget::eventFilter(QObject *obj, QEvent *event) { + if(event->type() == QEvent::FocusOut) { + switchPlain(); + return true; + } + if(event->type() != QEvent::KeyPress) return QObject::eventFilter(obj, event);