From f67fb34e69250fecd53b36acb67f15ad7ece893f Mon Sep 17 00:00:00 2001 From: Richard Ramos Date: Thu, 28 May 2020 18:22:51 -0400 Subject: [PATCH] Add scrollbar to chat messages --- .../Chat/ChatColumn/ChatMessages.qml | 57 +++++++++++-------- 1 file changed, 34 insertions(+), 23 deletions(-) diff --git a/ui/app/AppLayouts/Chat/ChatColumn/ChatMessages.qml b/ui/app/AppLayouts/Chat/ChatColumn/ChatMessages.qml index 49caf019e6..0d918121dd 100644 --- a/ui/app/AppLayouts/Chat/ChatColumn/ChatMessages.qml +++ b/ui/app/AppLayouts/Chat/ChatColumn/ChatMessages.qml @@ -1,39 +1,50 @@ -import QtQuick 2.3 +import QtQuick 2.14 import QtQuick.Controls 2.3 -import QtQuick.Controls 2.12 as QQC2 +import QtQuick.Controls 2.14 as QQC2 import QtQuick.Layouts 1.3 import Qt.labs.platform 1.1 import "../../../../shared" import "../../../../imports" import "./samples/" -ListView { +ScrollView { property var messageList: MessagesData {} - spacing: 4 - id: chatLogView - model: messageList + + anchors.fill: parent Layout.fillWidth: true Layout.fillHeight: true - delegate: Message { - userName: model.userName - message: model.message - identicon: model.identicon - isCurrentUser: model.isCurrentUser - repeatMessageInfo: model.repeatMessageInfo - timestamp: model.timestamp - } - highlightFollowsCurrentItem: true - onCountChanged: { - if (!this.atYEnd) { - // User has scrolled up, we don't want to scroll back - return + ScrollBar.vertical.policy: chatLogView.contentHeight > chatLogView.height ? ScrollBar.AlwaysOn : ScrollBar.AlwaysOff + ScrollBar.horizontal.policy: ScrollBar.AlwaysOff + + ListView { + anchors.fill: parent + spacing: 4 + id: chatLogView + model: messageList + Layout.fillWidth: true + Layout.fillHeight: true + delegate: Message { + userName: model.userName + message: model.message + identicon: model.identicon + isCurrentUser: model.isCurrentUser + repeatMessageInfo: model.repeatMessageInfo + timestamp: model.timestamp } + highlightFollowsCurrentItem: true - // positionViewAtEnd doesn't work well. Instead, we use highlightFollowsCurrentItem - // and set the current Item/Index to the latest item - while (this.currentIndex < this.count - 1) { - this.incrementCurrentIndex() + onCountChanged: { + if (!this.atYEnd) { + // User has scrolled up, we don't want to scroll back + return + } + + // positionViewAtEnd doesn't work well. Instead, we use highlightFollowsCurrentItem + // and set the current Item/Index to the latest item + while (this.currentIndex < this.count - 1) { + this.incrementCurrentIndex() + } } } }