This fixes #4 but introduces a new bug where the HTML in the strings in the sidebar is not converted to text anymore.
74 lines
1.7 KiB
QML
74 lines
1.7 KiB
QML
import QtQuick 2.0
|
|
import TTRSS 1.0
|
|
import QtQuick.Controls 1.3
|
|
import QtQuick.Layouts 1.1
|
|
import QtQuick.Controls.Styles 1.3
|
|
|
|
ScrollView {
|
|
id: item
|
|
|
|
property Server server
|
|
property Content content
|
|
property Post previousPost
|
|
property int textFontSize: 14
|
|
property bool nightmode
|
|
|
|
style: ScrollViewStyle {
|
|
transientScrollBars: true
|
|
}
|
|
|
|
function next() {
|
|
if(listView.count > listView.currentIndex) {
|
|
listView.currentIndex++;
|
|
}
|
|
}
|
|
|
|
function previous() {
|
|
if(listView.currentIndex > 0) {
|
|
listView.currentIndex--;
|
|
}
|
|
}
|
|
|
|
ListView {
|
|
id: listView
|
|
|
|
focus: true
|
|
anchors.fill: parent
|
|
spacing: 1
|
|
model: item.server.posts
|
|
|
|
delegate: Component {
|
|
PostListItem {
|
|
textFontSize: item.textFontSize
|
|
nightmode: app.nightmode
|
|
width: listView.width
|
|
}
|
|
}
|
|
|
|
highlightFollowsCurrentItem: false
|
|
highlight: Component {
|
|
Rectangle {
|
|
width: listView.currentItem.width
|
|
height: listView.currentItem.height
|
|
color: nightmode ? "#222" : "lightblue"
|
|
opacity: 0.5
|
|
y: listView.currentItem.y
|
|
}
|
|
}
|
|
|
|
onCurrentItemChanged: {
|
|
if(previousPost) {
|
|
if(!previousPost.dontChangeRead) {
|
|
previousPost.read = true;
|
|
} else {
|
|
previousPost.dontChangeRead = false;
|
|
}
|
|
}
|
|
|
|
item.content.post = server.posts[currentIndex]
|
|
//content.flickableItem.contentY = 0
|
|
|
|
previousPost = item.content.post
|
|
}
|
|
}
|
|
}
|