diff options
author | Tulir Asokan <tulir@maunium.net> | 2018-05-15 18:45:09 +0300 |
---|---|---|
committer | Tulir Asokan <tulir@maunium.net> | 2018-05-15 18:47:34 +0300 |
commit | cb3a6e764e3bd9023986bbce22ea971e7aa0a9d9 (patch) | |
tree | cedc6aadaec21ba4ddd0d5d1d0d1a66e9acbc7dd /matrix | |
parent | fdbb168e2bd4ba6eca864a41c0d1906669fb5fbe (diff) |
Fix room ordering after initial sync (ref #36)
Diffstat (limited to 'matrix')
-rw-r--r-- | matrix/matrix.go | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/matrix/matrix.go b/matrix/matrix.go index 7bb790e..7fbef5f 100644 --- a/matrix/matrix.go +++ b/matrix/matrix.go @@ -182,6 +182,7 @@ func (c *Container) OnLogin() { c.syncer.OnEventType("m.tag", c.HandleTag) c.syncer.InitDoneCallback = func() { c.config.Session.InitialSyncDone = true + c.ui.MainView().InitialSyncDone() c.ui.Render() } c.client.Syncer = c.syncer @@ -241,6 +242,7 @@ func (c *Container) HandleMessage(source EventSource, evt *gomatrix.Event) { message := mainView.ParseEvent(roomView, evt) if message != nil { roomView.AddMessage(message, ifc.AppendMessage) + roomView.MxRoom().LastReceivedMessage = message.Timestamp() if c.syncer.FirstSyncDone { pushRules := c.PushRules().GetActions(roomView.MxRoom(), evt).Should() mainView.NotifyMessage(roomView.MxRoom(), message, pushRules) @@ -333,6 +335,7 @@ func (c *Container) HandleMembership(source EventSource, evt *gomatrix.Event) { message := mainView.ParseEvent(roomView, evt) if message != nil { roomView.AddMessage(message, ifc.AppendMessage) + roomView.MxRoom().LastReceivedMessage = message.Timestamp() // We don't want notifications at startup. if c.syncer.FirstSyncDone { pushRules := c.PushRules().GetActions(roomView.MxRoom(), evt).Should() |