mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-20 17:54:36 +00:00
Lazy loading for the tweets
This commit is contained in:
parent
417c9bf609
commit
88d9be953b
4 changed files with 47 additions and 28 deletions
|
@ -36,6 +36,11 @@ Rectangle {
|
||||||
width: 330
|
width: 330
|
||||||
color: "#FFFFFF"
|
color: "#FFFFFF"
|
||||||
|
|
||||||
|
function updateTweets() {
|
||||||
|
tabView.twitter.item.updateTweets()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
TabView {
|
TabView {
|
||||||
id: tabView
|
id: tabView
|
||||||
anchors.left: parent.left
|
anchors.left: parent.left
|
||||||
|
@ -45,12 +50,18 @@ Rectangle {
|
||||||
anchors.leftMargin: 14
|
anchors.leftMargin: 14
|
||||||
anchors.rightMargin: 14
|
anchors.rightMargin: 14
|
||||||
anchors.topMargin: 40
|
anchors.topMargin: 40
|
||||||
|
property alias twitter: twitter
|
||||||
|
|
||||||
Tab { title: qsTr("Twitter"); source: "tabs/Twitter.qml" }
|
|
||||||
|
|
||||||
|
|
||||||
|
Tab { id: twitter; title: qsTr("Twitter"); source: "tabs/Twitter.qml" }
|
||||||
Tab { title: "News" }
|
Tab { title: "News" }
|
||||||
Tab { title: "Help" }
|
Tab { title: "Help" }
|
||||||
Tab { title: "About" }
|
Tab { title: "About" }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
style: TabViewStyle {
|
style: TabViewStyle {
|
||||||
frameOverlap: 0
|
frameOverlap: 0
|
||||||
tabOverlap: 0
|
tabOverlap: 0
|
||||||
|
|
6
main.qml
6
main.qml
|
@ -210,6 +210,12 @@ ApplicationWindow {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onRightPanelExpandedChanged: {
|
||||||
|
if (rightPanelExpanded) {
|
||||||
|
rightPanel.updateTweets()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Settings {
|
Settings {
|
||||||
id: persistentSettings
|
id: persistentSettings
|
||||||
property string language
|
property string language
|
||||||
|
|
|
@ -56,47 +56,41 @@ Item {
|
||||||
|
|
||||||
function reload() {
|
function reload() {
|
||||||
tweets.clear()
|
tweets.clear()
|
||||||
|
|
||||||
if (from == "" && phrase == "")
|
if (from == "" && phrase == "")
|
||||||
return;
|
return;
|
||||||
|
//! [requesting]
|
||||||
if (appWindow.rightPanelExpanded) {
|
var req = new XMLHttpRequest;
|
||||||
|
req.open("GET", "https://api.twitter.com/1.1/search/tweets.json?from=" + from +
|
||||||
//! [requesting]
|
"&count=" + tweetsMaxCount + "&q=" + encodePhrase(phrase));
|
||||||
var req = new XMLHttpRequest;
|
req.setRequestHeader("Authorization", "Bearer " + bearerToken);
|
||||||
req.open("GET", "https://api.twitter.com/1.1/search/tweets.json?from=" + from +
|
req.onreadystatechange = function() {
|
||||||
"&count=" + tweetsMaxCount + "&q=" + encodePhrase(phrase));
|
status = req.readyState;
|
||||||
req.setRequestHeader("Authorization", "Bearer " + bearerToken);
|
if (status === XMLHttpRequest.DONE) {
|
||||||
req.onreadystatechange = function() {
|
var objectArray = JSON.parse(req.responseText);
|
||||||
status = req.readyState;
|
if (objectArray.errors !== undefined)
|
||||||
if (status === XMLHttpRequest.DONE) {
|
console.log("Error fetching tweets: " + objectArray.errors[0].message)
|
||||||
var objectArray = JSON.parse(req.responseText);
|
else {
|
||||||
if (objectArray.errors !== undefined)
|
for (var key in objectArray.statuses) {
|
||||||
console.log("Error fetching tweets: " + objectArray.errors[0].message)
|
var jsonObject = objectArray.statuses[key];
|
||||||
else {
|
tweets.append(jsonObject);
|
||||||
for (var key in objectArray.statuses) {
|
|
||||||
var jsonObject = objectArray.statuses[key];
|
|
||||||
tweets.append(jsonObject);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
if (wasLoading == true)
|
|
||||||
wrapper.isLoaded()
|
|
||||||
}
|
}
|
||||||
wasLoading = (status === XMLHttpRequest.LOADING);
|
if (wasLoading == true)
|
||||||
|
wrapper.isLoaded()
|
||||||
}
|
}
|
||||||
req.send();
|
wasLoading = (status === XMLHttpRequest.LOADING);
|
||||||
//! [requesting]
|
|
||||||
}
|
}
|
||||||
|
req.send();
|
||||||
|
//! [requesting]
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
Component.onCompleted: {
|
Component.onCompleted: {
|
||||||
if (consumerKey === "" || consumerSecret == "") {
|
if (consumerKey === "" || consumerSecret == "") {
|
||||||
console.log("setting demo token")
|
console.log("setting demo token")
|
||||||
bearerToken = encodeURIComponent(Helper.demoToken())
|
bearerToken = encodeURIComponent(Helper.demoToken())
|
||||||
tweetsModel.phrase = ""
|
tweetsModel.phrase = ""
|
||||||
tweetsModel.from = "@monerocurrency"
|
tweetsModel.from = "@monerocurrency"
|
||||||
reload()
|
// reload()
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -34,6 +34,8 @@ import "../components"
|
||||||
Item {
|
Item {
|
||||||
id: tab
|
id: tab
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
ListModel {
|
ListModel {
|
||||||
id: testModel
|
id: testModel
|
||||||
ListElement { head: "Monero || #xmr"; foot: "<b>@btcplanet</b> Duis turpis arcu, varius nec rutrum in, adipiscing at enim. Donec quis consequat ipsum," }
|
ListElement { head: "Monero || #xmr"; foot: "<b>@btcplanet</b> Duis turpis arcu, varius nec rutrum in, adipiscing at enim. Donec quis consequat ipsum," }
|
||||||
|
@ -56,10 +58,16 @@ Item {
|
||||||
property var idx
|
property var idx
|
||||||
property var ids
|
property var ids
|
||||||
|
|
||||||
|
function updateTweets() {
|
||||||
|
tweetsModel.reload()
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Component.onCompleted: {
|
Component.onCompleted: {
|
||||||
ids = new Array()
|
ids = new Array()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
function idInModel(id) {
|
function idInModel(id) {
|
||||||
for (var j = 0; j < ids.length; j++)
|
for (var j = 0; j < ids.length; j++)
|
||||||
if (ids[j] === id)
|
if (ids[j] === id)
|
||||||
|
|
Loading…
Reference in a new issue