feat(@desktop/wallet): adapt to multiclient collectibles api

This commit is contained in:
Dario Gabriel Lipicar 2023-08-10 17:46:45 -03:00 committed by dlipicar
parent e9d0727ea1
commit 21eea92d34
7 changed files with 49 additions and 14 deletions

View File

@ -19,6 +19,8 @@ QtObject:
eventsHandler: EventsHandler eventsHandler: EventsHandler
requestId: int32
proc setup(self: Controller) = proc setup(self: Controller) =
self.QObject.setup self.QObject.setup
@ -91,7 +93,7 @@ QtObject:
self.detailedEntry = newCollectibleDetailsBasicEntry(id, extradata) self.detailedEntry = newCollectibleDetailsBasicEntry(id, extradata)
self.detailedEntryChanged() self.detailedEntryChanged()
let response = backend_collectibles.getCollectiblesDetailsAsync(@[id]) let response = backend_collectibles.getCollectiblesDetailsAsync(self.requestId, @[id])
if response.error != nil: if response.error != nil:
self.setIsDetailedEntryLoading(false) self.setIsDetailedEntryLoading(false)
error "error fetching collectible details: ", response.error error "error fetching collectible details: ", response.error
@ -102,16 +104,20 @@ QtObject:
self.processGetCollectiblesDetailsResponse(jsonObj) self.processGetCollectiblesDetailsResponse(jsonObj)
) )
proc newController*(networkService: network_service.Service, proc newController*(requestId: int32,
networkService: network_service.Service,
events: EventEmitter events: EventEmitter
): Controller = ): Controller =
new(result, delete) new(result, delete)
result.requestId = requestId
result.networkService = networkService result.networkService = networkService
result.detailedEntry = newCollectibleDetailsEmptyEntry() result.detailedEntry = newCollectibleDetailsEmptyEntry()
result.isDetailedEntryLoading = false result.isDetailedEntryLoading = false
result.eventsHandler = newEventsHandler(events) result.eventsHandler = newEventsHandler(result.requestId, events)
result.setup() result.setup()

View File

@ -1,4 +1,4 @@
import NimQml, logging, std/json, sequtils, strutils import NimQml, logging, std/json, sequtils, strutils, options
import tables, stint import tables, stint
import app/core/eventemitter import app/core/eventemitter
@ -15,6 +15,8 @@ QtObject:
events: EventEmitter events: EventEmitter
eventHandlers: Table[string, EventCallbackProc] eventHandlers: Table[string, EventCallbackProc]
requestId: int32
proc setup(self: EventsHandler) = proc setup(self: EventsHandler) =
self.QObject.setup self.QObject.setup
@ -27,6 +29,9 @@ QtObject:
proc handleApiEvents(self: EventsHandler, e: Args) = proc handleApiEvents(self: EventsHandler, e: Args) =
var data = WalletSignal(e) var data = WalletSignal(e)
if data.requestId.isSome and data.requestId.get() != self.requestId:
return
if self.eventHandlers.hasKey(data.eventType): if self.eventHandlers.hasKey(data.eventType):
var responseJson: JsonNode var responseJson: JsonNode
responseJson = parseJson(data.message) responseJson = parseJson(data.message)
@ -39,8 +44,11 @@ QtObject:
else: else:
discard discard
proc newEventsHandler*(events: EventEmitter): EventsHandler = proc newEventsHandler*(requestId: int32, events: EventEmitter): EventsHandler =
new(result, delete) new(result, delete)
result.requestId = requestId
result.events = events result.events = events
result.eventHandlers = initTable[string, EventCallbackProc]() result.eventHandlers = initTable[string, EventCallbackProc]()

View File

@ -22,6 +22,8 @@ QtObject:
addresses: seq[string] addresses: seq[string]
chainIds: seq[int] chainIds: seq[int]
requestId: int32
proc setup(self: Controller) = proc setup(self: Controller) =
self.QObject.setup self.QObject.setup
@ -68,7 +70,7 @@ QtObject:
offset = self.model.getCollectiblesCount() offset = self.model.getCollectiblesCount()
self.fetchFromStart = false self.fetchFromStart = false
let response = backend_collectibles.filterOwnedCollectiblesAsync(self.chainIds, self.addresses, offset, FETCH_BATCH_COUNT_DEFAULT) let response = backend_collectibles.filterOwnedCollectiblesAsync(self.requestId, self.chainIds, self.addresses, offset, FETCH_BATCH_COUNT_DEFAULT)
if response.error != nil: if response.error != nil:
self.model.setIsFetching(false) self.model.setIsFetching(false)
self.model.setIsError(true) self.model.setIsError(true)
@ -89,13 +91,15 @@ QtObject:
self.model.setIsUpdating(false) self.model.setIsUpdating(false)
) )
proc newController*(events: EventEmitter): Controller = proc newController*(requestId: int32, events: EventEmitter): Controller =
new(result, delete) new(result, delete)
result.requestId = requestId
result.model = newModel() result.model = newModel()
result.fetchFromStart = true result.fetchFromStart = true
result.eventsHandler = newEventsHandler(events) result.eventsHandler = newEventsHandler(result.requestId, events)
result.addresses = @[] result.addresses = @[]
result.chainIds = @[] result.chainIds = @[]

View File

@ -1,4 +1,4 @@
import NimQml, logging, std/json, sequtils, strutils import NimQml, logging, std/json, sequtils, strutils, options
import tables, stint, sets import tables, stint, sets
import app/core/eventemitter import app/core/eventemitter
@ -23,6 +23,8 @@ QtObject:
collectiblesOwnershipUpdateStartedFn: proc() collectiblesOwnershipUpdateStartedFn: proc()
collectiblesOwnershipUpdateFinishedFn: proc() collectiblesOwnershipUpdateFinishedFn: proc()
requestId: int32
proc setup(self: EventsHandler) = proc setup(self: EventsHandler) =
self.QObject.setup self.QObject.setup
@ -41,6 +43,9 @@ QtObject:
proc handleApiEvents(self: EventsHandler, e: Args) = proc handleApiEvents(self: EventsHandler, e: Args) =
var data = WalletSignal(e) var data = WalletSignal(e)
if data.requestId.isSome and data.requestId.get() != self.requestId:
return
if self.walletEventHandlers.hasKey(data.eventType): if self.walletEventHandlers.hasKey(data.eventType):
let callback = self.walletEventHandlers[data.eventType] let callback = self.walletEventHandlers[data.eventType]
callback(data) callback(data)
@ -74,8 +79,11 @@ QtObject:
return return
self.collectiblesOwnershipUpdateFinishedFn() self.collectiblesOwnershipUpdateFinishedFn()
proc newEventsHandler*(events: EventEmitter): EventsHandler = proc newEventsHandler*(requestId: int32, events: EventEmitter): EventsHandler =
new(result, delete) new(result, delete)
result.requestId = requestId
result.events = events result.events = events
result.eventHandlers = initTable[string, EventCallbackProc]() result.eventHandlers = initTable[string, EventCallbackProc]()

View File

@ -32,6 +32,8 @@ import ../../../../app_service/service/accounts/service as accounts_service
import ../../../../app_service/service/node/service as node_service import ../../../../app_service/service/node/service as node_service
import ../../../../app_service/service/network_connection/service as network_connection_service import ../../../../app_service/service/network_connection/service as network_connection_service
import backend/collectibles as backend_collectibles
logScope: logScope:
topics = "wallet-section-module" topics = "wallet-section-module"
@ -108,8 +110,8 @@ proc newModule*(
result.transactionService = transactionService result.transactionService = transactionService
result.activityController = activityc.newController(int32(ActivityID.History), currencyService, tokenService, events) result.activityController = activityc.newController(int32(ActivityID.History), currencyService, tokenService, events)
result.tmpActivityController = activityc.newController(int32(ActivityID.Temporary), currencyService, tokenService, events) result.tmpActivityController = activityc.newController(int32(ActivityID.Temporary), currencyService, tokenService, events)
result.collectiblesController = collectiblesc.newController(events) result.collectiblesController = collectiblesc.newController(int32(backend_collectibles.CollectiblesRequestID.WalletAccount), events)
result.collectibleDetailsController = collectible_detailsc.newController(networkService, events) result.collectibleDetailsController = collectible_detailsc.newController(int32(backend_collectibles.CollectiblesRequestID.WalletAccount), networkService, events)
result.filter = initFilter(result.controller) result.filter = initFilter(result.controller)
result.view = newView(result, result.activityController, result.tmpActivityController, result.collectiblesController, result.collectibleDetailsController) result.view = newView(result, result.activityController, result.tmpActivityController, result.collectiblesController, result.collectibleDetailsController)

View File

@ -8,6 +8,11 @@ from ./gen import rpc
export response_type, collectibles_types export response_type, collectibles_types
type
CollectiblesRequestID* = enum
WalletAccount
ProfileShowcase
# Declared in services/wallet/collectibles/service.go # Declared in services/wallet/collectibles/service.go
const eventCollectiblesOwnershipUpdateStarted*: string = "wallet-collectibles-ownership-update-started" const eventCollectiblesOwnershipUpdateStarted*: string = "wallet-collectibles-ownership-update-started"
const eventCollectiblesOwnershipUpdateFinished*: string = "wallet-collectibles-ownership-update-finished" const eventCollectiblesOwnershipUpdateFinished*: string = "wallet-collectibles-ownership-update-finished"
@ -86,10 +91,12 @@ rpc(getCollectibleOwnersByContractAddress, "wallet"):
contractAddress: string contractAddress: string
rpc(filterOwnedCollectiblesAsync, "wallet"): rpc(filterOwnedCollectiblesAsync, "wallet"):
requestId: int32
chainIDs: seq[int] chainIDs: seq[int]
addresses: seq[string] addresses: seq[string]
offset: int offset: int
limit: int limit: int
rpc(getCollectiblesDetailsAsync, "wallet"): rpc(getCollectiblesDetailsAsync, "wallet"):
requestId: int32
uniqueIds: seq[CollectibleUniqueID] uniqueIds: seq[CollectibleUniqueID]

2
vendor/status-go vendored

@ -1 +1 @@
Subproject commit 9d0acc2265bc19bbd3c5b6555ca538e678c7677f Subproject commit 25ff1dd75899e697aa80ccf795c32fcb6ed60c33