fix(Communities): receive community info after community import

This commit ensures that, once a community was imported, the application
will listen to the newly introduced `community.found` signal, which will be
emitted by status-go.

The signal exposes a `Community` object that is then used to add a
community item to the community list in the UI.

**This can only land after https://github.com/status-im/status-go/pull/2177 has landed first!**

Fixes #2024
This commit is contained in:
Pascal Precht 2021-04-09 12:03:27 +02:00 committed by Jonathan Rainville
parent 6a9bd579d1
commit bceed7b7aa
7 changed files with 26 additions and 1 deletions

View File

@ -28,6 +28,10 @@ proc handleSignals(self: ChatController) =
let chatId = self.status.messages.messages[messageId].chatId let chatId = self.status.messages.messages[messageId].chatId
self.view.messageList[chatId].checkTimeout(messageId) self.view.messageList[chatId].checkTimeout(messageId)
self.status.events.on(SignalType.CommunityFound.event) do(e: Args):
var data = CommunitySignal(e)
self.view.communities.addCommunityToList(data.community)
self.status.events.on(SignalType.MailserverRequestCompleted.event) do(e:Args): self.status.events.on(SignalType.MailserverRequestCompleted.event) do(e:Args):
# TODO: if the signal contains a cursor, request additional messages # TODO: if the signal contains a cursor, request additional messages
# else: # else:

View File

@ -461,6 +461,9 @@ proc createCommunityChannel*(self: ChatModel, communityId: string, name: string,
proc joinCommunity*(self: ChatModel, communityId: string) = proc joinCommunity*(self: ChatModel, communityId: string) =
status_chat.joinCommunity(communityId) status_chat.joinCommunity(communityId)
proc requestCommunityInfo*(self: ChatModel, communityId: string) =
status_chat.requestCommunityInfo(communityId)
proc leaveCommunity*(self: ChatModel, communityId: string) = proc leaveCommunity*(self: ChatModel, communityId: string) =
status_chat.leaveCommunity(communityId) status_chat.leaveCommunity(communityId)

View File

@ -314,6 +314,9 @@ proc createCommunityChannel*(communityId: string, name: string, description: str
if rpcResult{"result"}.kind != JNull: if rpcResult{"result"}.kind != JNull:
result = rpcResult["result"]["chats"][0].toChat() result = rpcResult["result"]["chats"][0].toChat()
proc requestCommunityInfo*(communityId: string) =
discard callPrivateRPC("requestCommunityInfoFromMailserver".prefix, %*[communityId])
proc joinCommunity*(communityId: string) = proc joinCommunity*(communityId: string) =
discard callPrivateRPC("joinCommunity".prefix, %*[communityId]) discard callPrivateRPC("joinCommunity".prefix, %*[communityId])

View File

@ -21,6 +21,7 @@ type SignalType* {.pure.} = enum
SubscriptionsData = "subscriptions.data" SubscriptionsData = "subscriptions.data"
SubscriptionsError = "subscriptions.error" SubscriptionsError = "subscriptions.error"
WhisperFilterAdded = "whisper.filter.added" WhisperFilterAdded = "whisper.filter.added"
CommunityFound = "community.found"
Unknown Unknown
proc event*(self:SignalType):string = proc event*(self:SignalType):string =

View File

@ -0,0 +1,10 @@
import json, strutils, sequtils, sugar, chronicles
import json_serialization
import ../libstatus/types as status_types
import ../chat/[chat]
import types, messages
proc fromEvent*(event: JsonNode): Signal =
var signal: CommunitySignal = CommunitySignal()
signal.community = event["event"].toCommunity()
result = signal

View File

@ -1,6 +1,6 @@
import NimQml, tables, json, chronicles, strutils, json_serialization import NimQml, tables, json, chronicles, strutils, json_serialization
import ../libstatus/types as status_types import ../libstatus/types as status_types
import types, messages, discovery, whisperFilter, envelopes, expired, wallet, mailserver import types, messages, discovery, whisperFilter, envelopes, expired, wallet, mailserver, communities
import ../status import ../status
import ../../eventemitter import ../../eventemitter
@ -56,6 +56,7 @@ QtObject:
of SignalType.DiscoverySummary: discovery.fromEvent(jsonSignal) of SignalType.DiscoverySummary: discovery.fromEvent(jsonSignal)
of SignalType.MailserverRequestCompleted: mailserver.fromCompletedEvent(jsonSignal) of SignalType.MailserverRequestCompleted: mailserver.fromCompletedEvent(jsonSignal)
of SignalType.MailserverRequestExpired: mailserver.fromExpiredEvent(jsonSignal) of SignalType.MailserverRequestExpired: mailserver.fromExpiredEvent(jsonSignal)
of SignalType.CommunityFound: communities.fromEvent(jsonSignal)
else: Signal() else: Signal()
if(signalType == SignalType.NodeLogin): if(signalType == SignalType.NodeLogin):

View File

@ -36,6 +36,9 @@ type MessageSignal* = ref object of Signal
communities*: seq[Community] communities*: seq[Community]
membershipRequests*: seq[CommunityMembershipRequest] membershipRequests*: seq[CommunityMembershipRequest]
type CommunitySignal* = ref object of Signal
community*: Community
type MailserverRequestCompletedSignal* = ref object of Signal type MailserverRequestCompletedSignal* = ref object of Signal
requestID*: string requestID*: string
lastEnvelopeHash*: string lastEnvelopeHash*: string