[polari/wip/kunaljain/polari-search-result-view] add loading indicator
- From: Kunal Jain <kunaljain src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [polari/wip/kunaljain/polari-search-result-view] add loading indicator
- Date: Tue, 19 Jul 2016 07:50:33 +0000 (UTC)
commit 1c1ed09656f4eaba83240ad23594c18c3f334da6
Author: Kunaal Jain <kunaalus gmail com>
Date: Tue Jul 19 13:20:13 2016 +0530
add loading indicator
src/resultView.js | 55 +++++++++++++++++++++++++++++++++++++++-------------
1 files changed, 41 insertions(+), 14 deletions(-)
---
diff --git a/src/resultView.js b/src/resultView.js
index e5768f8..e74e880 100644
--- a/src/resultView.js
+++ b/src/resultView.js
@@ -220,7 +220,7 @@ const ResultView = new Lang.Class({
Tp.ChannelTextMessageType.NORMAL,
timestamp,
channel);
- log(sparql);
+ // log(sparql);
let sparql1 = (
'select nie:plainTextContent(?msg) as ?message ' +
'?msg as ?id ' +
@@ -254,7 +254,7 @@ const ResultView = new Lang.Class({
buffer.set_text("",-1);
this._endQuery = new LogManager.GenericQuery(this._logManager._connection, 20);
this._endQuery.run(sparql,this._cancellable,Lang.bind(this, this._onLogEventsReady1));
- log("!");
+ // log("!");
this._startQuery = new LogManager.GenericQuery(this._logManager._connection, 20);
// Mainloop.timeout_add(500, Lang.bind(this,
// function() {
@@ -375,7 +375,7 @@ const ResultView = new Lang.Class({
},
_onLogEventsReady: function(events) {
- print(events);
+ // print(events);
events = events.reverse();
this._hideLoadingIndicator();
@@ -385,9 +385,9 @@ const ResultView = new Lang.Class({
},
_onLogEventsReady1: function(events) {
- print(events);
+ // print(events);
//events = events.reverse();
- this._hideLoadingIndicator();
+ this._hideLoadingIndicator1();
this._pendingLogs = events.concat(this._pendingLogs);
this._insertPendingLogs1();
@@ -418,9 +418,9 @@ const ResultView = new Lang.Class({
if (index < 0)
return;*/
index = 0;
- print(this._pendingLogs);
+ // print(this._pendingLogs);
let pending = this._pendingLogs.splice(index);
- print(this._pendingLogs);
+ // print(this._pendingLogs);
print(pending);
let state = { lastNick: null, lastTimestamp: 0 };
let iter = this._view.buffer.get_start_iter();
@@ -475,10 +475,10 @@ const ResultView = new Lang.Class({
if (index < 0)
return;*/
index = 0;
- print(this._pendingLogs);
+ // print(this._pendingLogs);
let pending = this._pendingLogs.splice(index);
- print(this._pendingLogs);
- print(pending);
+ // print(this._pendingLogs);
+ // print(pending);
let state = { lastNick: null, lastTimestamp: 0 };
let iter = this._view.buffer.get_end_iter();
for (let i = 0; i < pending.length; i++) {
@@ -612,18 +612,20 @@ const ResultView = new Lang.Class({
return Gdk.EVENT_STOP;
this._fetchingBacklog = true;
- this._showLoadingIndicator();
- if (this.vadjustment.value == 0)
+ if (this.vadjustment.value == 0) {
+ this._showLoadingIndicator();
Mainloop.timeout_add(500, Lang.bind(this,
function() {
this._startQuery.next(10,this._cancellable,Lang.bind(this, this._onLogEventsReady));
}));
- else
+ } else {
+ this._showLoadingIndicator1();
Mainloop.timeout_add(500, Lang.bind(this,
function() {
this._endQuery.next(10,this._cancellable,Lang.bind(this, this._onLogEventsReady1));
}));
+ }
return Gdk.EVENT_STOP;
},
@@ -674,6 +676,32 @@ const ResultView = new Lang.Class({
buffer.delete(buffer.get_start_iter(), iter);
},
+ _showLoadingIndicator1: function() {
+ let indicator = new Gtk.Image({ icon_name: 'content-loading-symbolic',
+ visible: true });
+
+ let buffer = this._view.buffer;
+ let iter = buffer.get_end_iter();
+ buffer.insert(iter, '\n', -1);
+ let anchor = buffer.create_child_anchor(iter);
+ this._view.add_child_at_anchor(indicator, anchor);
+
+ let end = buffer.get_end_iter();
+ iter.backward_line();
+ buffer.remove_all_tags(iter, end);
+ buffer.apply_tag(this._lookupTag('loading'), iter, end);
+ },
+
+ _hideLoadingIndicator1: function() {
+ let buffer = this._view.buffer;
+ let iter = buffer.get_end_iter();
+ // if (!iter.get_child_anchor())
+ // return;
+
+ iter.backward_line();
+ buffer.delete(iter, buffer.get_end_iter());
+ },
+
_formatTimestamp: function(timestamp) {
let date = GLib.DateTime.new_from_unix_local(timestamp);
let now = GLib.DateTime.new_now_local();
@@ -756,7 +784,6 @@ const ResultView = new Lang.Class({
_insertMessage: function(iter, message, state) {
let isAction = message.messageType == Tp.ChannelTextMessageType.ACTION;
let needsGap = message.nick != state.lastNick || isAction;
- print(message.id == this._uid);
let isCentre = message.id == this._uid;
if (message.timestamp - TIMESTAMP_INTERVAL > state.lastTimestamp) {
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]