diff --git a/src/TopRoomBar.cc b/src/TopRoomBar.cc
index 8b2e338b..4d1f4195 100644
--- a/src/TopRoomBar.cc
+++ b/src/TopRoomBar.cc
@@ -52,11 +52,15 @@ TopRoomBar::TopRoomBar(QWidget *parent)
QFont descriptionFont("Open Sans");
descriptionFont.setPixelSize(conf::topRoomBar::fonts::roomDescription);
- topicLabel_ = new QLabel(this);
+ topicLabel_ = new Label(this);
topicLabel_->setFont(descriptionFont);
topicLabel_->setTextFormat(Qt::RichText);
topicLabel_->setTextInteractionFlags(Qt::TextBrowserInteraction);
topicLabel_->setOpenExternalLinks(true);
+ connect(topicLabel_, &Label::clicked, [=](QMouseEvent *e) {
+ if (e->button() == Qt::LeftButton && !topicLabel_->hasSelectedText())
+ topicLabel_->setWordWrap(!topicLabel_->wordWrap());
+ });
textLayout_->addWidget(nameLabel_);
textLayout_->addWidget(topicLabel_);
@@ -164,16 +168,35 @@ TopRoomBar::paintEvent(QPaintEvent *event)
QPainter painter(this);
style()->drawPrimitive(QStyle::PE_Widget, &option, &painter, this);
+ // Number of pixels that we can move sidebar splitter per frame. If label contains text
+ // which fills entire it's width then label starts blocking it's layout from shrinking.
+ // Making label little bit shorter leaves some space for it to shrink.
+ const auto perFrameResize = 20;
+
QString elidedText =
- QFontMetrics(nameLabel_->font()).elidedText(roomName_, Qt::ElideRight, width());
+ QFontMetrics(nameLabel_->font())
+ .elidedText(roomName_, Qt::ElideRight, nameLabel_->width() - perFrameResize);
nameLabel_->setText(elidedText);
- elidedText =
- QFontMetrics(topicLabel_->font()).elidedText(roomTopic_, Qt::ElideRight, width());
+ if (topicLabel_->wordWrap())
+ elidedText = roomTopic_;
+ else
+ elidedText =
+ QFontMetrics(topicLabel_->font())
+ .elidedText(roomTopic_, Qt::ElideRight, topicLabel_->width() - perFrameResize);
+ elidedText.replace(URL_REGEX, URL_HTML);
topicLabel_->setText(elidedText);
}
void
+TopRoomBar::mousePressEvent(QMouseEvent *event)
+{
+ if (childAt(event->pos()) == topicLabel_) {
+ event->accept();
+ }
+}
+
+void
TopRoomBar::setRoomSettings(QSharedPointer<RoomSettings> settings)
{
roomSettings_ = settings;
diff --git a/src/ui/Label.cc b/src/ui/Label.cc
new file mode 100644
index 00000000..8bd8c54e
--- /dev/null
+++ b/src/ui/Label.cc
@@ -0,0 +1,44 @@
+/*
+ * nheko Copyright (C) 2017 Konstantinos Sideris <siderisk@auth.gr>
+ *
+ * This program 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 3 of the License, or
+ * (at your option) any later version.
+ *
+ * This program 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 this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+#include "Label.h"
+#include <QMouseEvent>
+
+Label::Label(QWidget *parent, Qt::WindowFlags f)
+ : QLabel(parent, f)
+{}
+
+Label::Label(const QString &text, QWidget *parent, Qt::WindowFlags f)
+ : QLabel(text, parent, f)
+{}
+
+void
+Label::mousePressEvent(QMouseEvent *e)
+{
+ pressPosition_ = e->pos();
+ emit pressed(e);
+ QLabel::mousePressEvent(e);
+}
+
+void
+Label::mouseReleaseEvent(QMouseEvent *e)
+{
+ emit released(e);
+ if (pressPosition_ == e->pos())
+ emit clicked(e);
+ QLabel::mouseReleaseEvent(e);
+}
|