- }
-}
-
-void BufferWidget::removeBuffer(BufferId bufferId) {
- if(!_chatWidgets.contains(bufferId))
- return;
-
- if(Client::buffer(bufferId)) Client::buffer(bufferId)->setVisible(false);
- ChatWidget *chatWidget = _chatWidgets.take(bufferId);
- ui.stackedWidget->removeWidget(chatWidget);
- chatWidget->deleteLater();
-}
-
-void BufferWidget::currentChanged(const QModelIndex ¤t, const QModelIndex &previous) {
- BufferId newBufferId = current.data(NetworkModel::BufferIdRole).value<BufferId>();
- BufferId oldBufferId = previous.data(NetworkModel::BufferIdRole).value<BufferId>();
- if(newBufferId != oldBufferId)
- setCurrentBuffer(newBufferId);
-}
-
-void BufferWidget::setCurrentBuffer(BufferId bufferId) {
- if(!bufferId.isValid()) {
- ui.stackedWidget->setCurrentWidget(ui.page);
- return;
- }
-
- ChatWidget *chatWidget = 0;
- ChatView *chatView = 0;
- Buffer *buf = Client::buffer(bufferId);
- if(!buf) {
- qWarning() << "BufferWidget::setBuffer(BufferId): Can't show unknown Buffer:" << bufferId;
- return;
- }
- Buffer *prevBuffer = Client::buffer(currentBuffer());
- if(prevBuffer) prevBuffer->setVisible(false);
- if(Global::SPUTDEV) {
- if(_chatViews.contains(bufferId)) {
- chatView = _chatViews[bufferId];
- } else {
- chatView = new ChatView(buf, this);
- //chatView->init(bufferId);
- QList<ChatLine *> lines;
- QList<AbstractUiMsg *> msgs = buf->contents();
- foreach(AbstractUiMsg *msg, msgs) {
- lines.append(dynamic_cast<ChatLine *>(msg));
- }
- chatView->setContents(lines);
- connect(buf, SIGNAL(msgAppended(AbstractUiMsg *)), chatView, SLOT(appendMsg(AbstractUiMsg *)));
- connect(buf, SIGNAL(msgPrepended(AbstractUiMsg *)), chatView, SLOT(prependMsg(AbstractUiMsg *)));
- _chatViews[bufferId] = chatView;
- ui.stackedWidget->addWidget(chatView);
- chatView->setFocusProxy(this);
+}
+
+void BufferWidget::currentChanged(const QModelIndex& current, const QModelIndex& previous)
+{
+ auto* prevView = qobject_cast<ChatView*>(ui.stackedWidget->currentWidget());
+
+ AbstractBufferContainer::currentChanged(current, previous); // switch first to avoid a redraw
+
+ // we need to hide the marker line if it's already/still at the bottom of the view (and not scrolled up)
+ auto* curView = qobject_cast<ChatView*>(ui.stackedWidget->currentWidget());
+ if (curView) {
+ BufferId curBufferId = current.data(NetworkModel::BufferIdRole).value<BufferId>();
+ if (curBufferId.isValid()) {
+ MsgId markerMsgId = Client::networkModel()->markerLineMsgId(curBufferId);
+ if (markerMsgId == curView->lastMsgId() && markerMsgId == curView->lastVisibleMsgId())
+ curView->setMarkerLineVisible(false);
+ else
+ curView->setMarkerLineVisible(true);
+ }