summary refs log tree commit diff
path: root/resources/qml/TimelineView.qml
diff options
context:
space:
mode:
Diffstat (limited to 'resources/qml/TimelineView.qml')
-rw-r--r--resources/qml/TimelineView.qml238
1 files changed, 119 insertions, 119 deletions
diff --git a/resources/qml/TimelineView.qml b/resources/qml/TimelineView.qml
index c2f6f9b9..b25b3a7c 100644
--- a/resources/qml/TimelineView.qml
+++ b/resources/qml/TimelineView.qml
@@ -8,151 +8,151 @@ import com.github.nheko 1.0
 
 import "./delegates"
 
-Rectangle {
-	anchors.fill: parent
-
+Item {
 	property var colors: currentActivePalette
 	property var systemInactive: SystemPalette { colorGroup: SystemPalette.Disabled }
 	property var inactiveColors: currentInactivePalette ? currentInactivePalette : systemInactive
 	property int avatarSize: 40
 
-	color: colors.window
-
-	Text {
-		visible: !timelineManager.timeline
-		anchors.centerIn: parent
-		text: qsTr("No room open")
-		font.pointSize: 24
-		color: colors.windowText
-	}
+	Rectangle {
+		anchors.fill: parent
+		color: colors.window
+
+		Text {
+			visible: !timelineManager.timeline
+			anchors.centerIn: parent
+			text: qsTr("No room open")
+			font.pointSize: 24
+			color: colors.windowText
+		}
 
-	ListView {
-		id: chat
+		ListView {
+			id: chat
 
-		cacheBuffer: 2000
+			cacheBuffer: 2000
 
-		visible: timelineManager.timeline != null
-		anchors.fill: parent
+			visible: timelineManager.timeline != null
+			anchors.fill: parent
 
-		anchors.leftMargin: 4
-		anchors.rightMargin: scrollbar.width
+			anchors.leftMargin: 4
+			anchors.rightMargin: scrollbar.width
 
-		model: timelineManager.timeline
+			model: timelineManager.timeline
 
-		onModelChanged: {
-			if (model) {
-				currentIndex = model.currentIndex
-				if (model.currentIndex == count - 1) {
-					positionViewAtEnd()
-				} else {
-					positionViewAtIndex(model.currentIndex, ListView.End)
-				}
+			onModelChanged: {
+				if (model) {
+					currentIndex = model.currentIndex
+					if (model.currentIndex == count - 1) {
+						positionViewAtEnd()
+					} else {
+						positionViewAtIndex(model.currentIndex, ListView.End)
+					}
 
-				if (contentHeight < height) {
-					model.fetchHistory();
+					//if (contentHeight < height) {
+					//	model.fetchHistory();
+					//}
 				}
 			}
-		}
 
-		ScrollBar.vertical: ScrollBar {
-			id: scrollbar
-			anchors.top: parent.top
-			anchors.left: parent.right
-			anchors.bottom: parent.bottom
-			onPressedChanged: if (!pressed) chat.updatePosition()
-		}
-
-		property bool atBottom: false
-		onCountChanged: {
-			if (atBottom && Window.active) {
-				var newIndex = count - 1 // last index
-				positionViewAtEnd()
-				currentIndex = newIndex
-				model.currentIndex = newIndex
+			ScrollBar.vertical: ScrollBar {
+				id: scrollbar
+				anchors.top: parent.top
+				anchors.left: parent.right
+				anchors.bottom: parent.bottom
+				onPressedChanged: if (!pressed) chat.updatePosition()
 			}
 
-			if (contentHeight < height && model) {
-				model.fetchHistory();
-			}
-		}
+			property bool atBottom: false
+			onCountChanged: {
+				if (atBottom) {
+					var newIndex = count - 1 // last index
+					positionViewAtEnd()
+					currentIndex = newIndex
+					model.currentIndex = newIndex
+				}
 
-		onAtYBeginningChanged: if (atYBeginning) model.fetchHistory()
-
-		function updatePosition() {
-			for (var y = chat.contentY + chat.height; y > chat.height; y -= 5) {
-				var i = chat.itemAt(100, y);
-				if (!i) continue;
-				if (!i.isFullyVisible()) continue;
-				chat.model.currentIndex = i.getIndex();
-				chat.currentIndex = i.getIndex()
-				atBottom = i.getIndex() == count - 1;
-				console.log("bottom:" + atBottom)
-				break;
+				if (contentHeight < height && model) {
+					model.fetchHistory();
+				}
 			}
-		}
-		onMovementEnded: updatePosition()
 
-		spacing: 4
-		delegate: TimelineRow {
-			function isFullyVisible() {
-				return height > 1 && (y - chat.contentY - 1) + height < chat.height
-			}
-			function getIndex() {
-				return index;
+			onAtYBeginningChanged: if (atYBeginning) model.fetchHistory()
+
+			function updatePosition() {
+				for (var y = chat.contentY + chat.height; y > chat.height; y -= 9) {
+					var i = chat.itemAt(100, y);
+					if (!i) continue;
+					if (!i.isFullyVisible()) continue;
+					chat.model.currentIndex = i.getIndex();
+					chat.currentIndex = i.getIndex()
+					atBottom = i.getIndex() == count - 1;
+					break;
+				}
 			}
-		}
+			onMovementEnded: updatePosition()
 
-		section {
-			property: "section"
-			delegate: Column {
-				topPadding: 4
-				bottomPadding: 4
-				spacing: 8
-
-				width: parent.width
-				height: (section.includes(" ") ? dateBubble.height + 8 + userName.height : userName.height) + 8
-
-				Label {
-					id: dateBubble
-					anchors.horizontalCenter: parent.horizontalCenter
-					visible: section.includes(" ")
-					text: chat.model.formatDateSeparator(new Date(Number(section.split(" ")[1])))
-					color: colors.windowText
-
-					height: contentHeight * 1.2
-					width: contentWidth * 1.2
-					horizontalAlignment: Text.AlignHCenter
-					background: Rectangle {
-						radius: parent.height / 2
-						color: colors.dark
-					}
+			spacing: 4
+			delegate: TimelineRow {
+				function isFullyVisible() {
+					return height > 1 && (y - chat.contentY - 1) + height < chat.height
 				}
-				Row {
-					height: userName.height
-					spacing: 4
-					Avatar {
-						width: avatarSize
-						height: avatarSize
-						url: chat.model.avatarUrl(section.split(" ")[0]).replace("mxc://", "image://MxcImage/")
-						displayName: chat.model.displayName(section.split(" ")[0])
-
-						MouseArea {
-							anchors.fill: parent
-							onClicked: chat.model.openUserProfile(section.split(" ")[0])
-							cursorShape: Qt.PointingHandCursor
+				function getIndex() {
+					return index;
+				}
+			}
+
+			section {
+				property: "section"
+				delegate: Column {
+					topPadding: 4
+					bottomPadding: 4
+					spacing: 8
+
+					width: parent.width
+					height: (section.includes(" ") ? dateBubble.height + 8 + userName.height : userName.height) + 8
+
+					Label {
+						id: dateBubble
+						anchors.horizontalCenter: parent.horizontalCenter
+						visible: section.includes(" ")
+						text: chat.model.formatDateSeparator(new Date(Number(section.split(" ")[1])))
+						color: colors.windowText
+
+						height: contentHeight * 1.2
+						width: contentWidth * 1.2
+						horizontalAlignment: Text.AlignHCenter
+						background: Rectangle {
+							radius: parent.height / 2
+							color: colors.dark
 						}
 					}
+					Row {
+						height: userName.height
+						spacing: 4
+						Avatar {
+							width: avatarSize
+							height: avatarSize
+							url: chat.model.avatarUrl(section.split(" ")[0]).replace("mxc://", "image://MxcImage/")
+							displayName: chat.model.displayName(section.split(" ")[0])
+
+							MouseArea {
+								anchors.fill: parent
+								onClicked: chat.model.openUserProfile(section.split(" ")[0])
+								cursorShape: Qt.PointingHandCursor
+							}
+						}
 
-					Text { 
-						id: userName
-						text: chat.model.escapeEmoji(chat.model.displayName(section.split(" ")[0]))
-						color: chat.model.userColor(section.split(" ")[0], colors.window)
-						textFormat: Text.RichText
-
-						MouseArea {
-							anchors.fill: parent
-							onClicked: chat.model.openUserProfile(section.split(" ")[0])
-							cursorShape: Qt.PointingHandCursor
+						Text { 
+							id: userName
+							text: chat.model.escapeEmoji(chat.model.displayName(section.split(" ")[0]))
+							color: chat.model.userColor(section.split(" ")[0], colors.window)
+							textFormat: Text.RichText
+
+							MouseArea {
+								anchors.fill: parent
+								onClicked: chat.model.openUserProfile(section.split(" ")[0])
+								cursorShape: Qt.PointingHandCursor
+							}
 						}
 					}
 				}