[polari/wip/fmuellner/combined-gsoc: 31/137] ResultView: Show relevant messages
- From: Florian Müllner <fmuellner src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [polari/wip/fmuellner/combined-gsoc: 31/137] ResultView: Show relevant messages
- Date: Thu, 28 Jul 2016 16:18:01 +0000 (UTC)
commit 74af87ed43ac8dfddb1dfcdc3462d35a27b5acc5
Author: Kunaal Jain <kunaalus gmail com>
Date: Sun Jul 3 20:00:42 2016 +0530
ResultView: Show relevant messages
data/resources/main-window.ui | 6 ++--
src/mainWindow.js | 75 ++++++++++++++++++++++++++++++++++++-----
2 files changed, 69 insertions(+), 12 deletions(-)
---
diff --git a/data/resources/main-window.ui b/data/resources/main-window.ui
index ff2b673..072ac49 100644
--- a/data/resources/main-window.ui
+++ b/data/resources/main-window.ui
@@ -213,7 +213,7 @@
<object class="Gjs_FixedSizeFrame" id="roomSidebar">
<property name="visible">True</property>
<property name="hexpand">False</property>
- <property name="width">200</property>
+ <!-- <property name="width">200</property> -->
<property name="shadow-type">none</property>
<style>
<class name="polari-room-list"/>
@@ -227,7 +227,7 @@
<object class="Gjs_FixedSizeFrame">
<property name="visible">True</property>
<property name="hexpand">False</property>
- <property name="width">200</property>
+ <!-- <property name="width">200</property> -->
<property name="shadow-type">none</property>
<child>
<object class="GtkScrolledWindow">
@@ -256,7 +256,7 @@
<object class="Gjs_FixedSizeFrame">
<property name="visible">True</property>
<property name="hexpand">False</property>
- <property name="width">200</property>
+ <!-- <property name="width">200</property> -->
<property name="shadow-type">none</property>
<child>
<object class="GtkScrolledWindow">
diff --git a/src/mainWindow.js b/src/mainWindow.js
index 9882565..8bc799e 100644
--- a/src/mainWindow.js
+++ b/src/mainWindow.js
@@ -274,13 +274,54 @@ const MainWindow = new Lang.Class({
},
_rowactivated: function(box, row) {
- let logManager = LogManager.getDefault();
- this._logWalker = logManager.walkEvents(row,
- row.channel);
-
- this._fetchingBacklog = true;
- this._logWalker.getEvents(10,
- Lang.bind(this, this._onLogEventsReady));
+ this._cancellable.cancel();
+ this._cancellable.reset();
+ let sparql = (
+ 'select nie:plainTextContent(?msg) as ?message ' +
+ ' if (nmo:from(?msg) = nco:default-contact-me,' +
+ ' "%s", nco:nickname(nmo:from(?msg))) as ?sender ' +
+ // FIXME: how do we handle the "real" message type?
+ ' %d as ?messageType ' +
+ ' ?timestamp ' +
+ '{ ?msg a nmo:IMMessage; ' +
+ ' nie:contentCreated ?timestamp; ' +
+ ' nmo:communicationChannel ?chan . ' +
+ 'BIND( ?timestamp - %s as ?timediff ) . ' +
+ // FIXME: filter by account
+ ' filter (nie:title (?chan) = "%s" && ?timediff >= 0) ' +
+ '} order by asc (?timestamp) LIMIT 10'
+ ).format(row.nickname,
+ Tp.ChannelTextMessageType.NORMAL,
+ row.timestamp,
+ row.channel);
+ log(sparql);
+ let sparql1 = (
+ 'select nie:plainTextContent(?msg) as ?message ' +
+ ' if (nmo:from(?msg) = nco:default-contact-me,' +
+ ' "%s", nco:nickname(nmo:from(?msg))) as ?sender ' +
+ // FIXME: how do we handle the "real" message type?
+ ' %d as ?messageType ' +
+ ' ?timestamp ' +
+ '{ ?msg a nmo:IMMessage; ' +
+ ' nie:contentCreated ?timestamp; ' +
+ ' nmo:communicationChannel ?chan . ' +
+ 'BIND( %s - ?timestamp as ?timediff ) . ' +
+ // FIXME: filter by account
+ ' filter (nie:title (?chan) = "%s" && ?timediff > 0) ' +
+ '} order by asc (?timestamp) LIMIT 10'
+ ).format(row.nickname,
+ Tp.ChannelTextMessageType.NORMAL,
+ row.timestamp,
+ row.channel);
+ // let logManager = LogManager.getDefault();
+ // this._logWalker = logManager.walkEvents(row,
+ // row.channel);
+ //
+ // this._fetchingBacklog = true;
+ // this._logWalker.getEvents(10,
+ // Lang.bind(this, this._onLogEventsReady));
+ this._logManager.query(sparql,this._cancellable,Lang.bind(this, this._onLogEventsReady));
+ this._logManager.query(sparql1,this._cancellable,Lang.bind(this, this._onLogEventsReady1));
let buffer = this._resultStack.get_buffer();
let iter = buffer.get_end_iter();
//this._resultStack.buffer.insert(iter,row._content_label.label, -1);
@@ -288,14 +329,29 @@ const MainWindow = new Lang.Class({
},
_onLogEventsReady: function(events) {
+ let buffer = this._resultStack.get_buffer();
+ buffer.set_text("",-1);
for (let i = 0; i < events.length; i++) {
- let buffer = this._resultStack.get_buffer();
+
let iter = buffer.get_end_iter();
- this._resultStack.buffer.insert(iter,events[i].message, -1);
+ this._resultStack.buffer.insert(iter,events[i].timestamp + "\t\t\t" + events[i].sender + " : " +
events[i].message, -1);
+ this._resultStack.buffer.insert(iter,'\n', -1);
+ }
+ },
+
+ _onLogEventsReady1: function(events) {
+ let buffer = this._resultStack.get_buffer();
+ // buffer.set_text("",-1);
+ let iter = buffer.get_start_iter();
+ // this._resultStack.buffer.insert(iter,'\n', -1);
+ iter = buffer.get_start_iter();
+ for (let i = 0; i < events.length; i++) {
+ this._resultStack.buffer.insert(iter,events[i].timestamp + "\t\t\t" + events[i].sender + " : " +
events[i].message, -1);
this._resultStack.buffer.insert(iter,'\n', -1);
}
},
+
_Log: function(events) {
log(events);
let widgetMap = {};
@@ -326,6 +382,7 @@ const MainWindow = new Lang.Class({
row.uid = events[i].id;
row.channel = channel;
row.nickname = channel;
+ row.timestamp = time;
widgetMap[uid] = row;
}
row._content_label.label = message;
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]