mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-19 14:40:26 +08:00
fix(thread-list): Don't rely on zip
since it can become off-by-one forever
This commit is contained in:
parent
b3ea335345
commit
765d9f30fc
1 changed files with 8 additions and 6 deletions
|
@ -18,13 +18,15 @@ _flatMapJoiningMessages = ($threadsResultSet) =>
|
||||||
# we make a single database query and load /all/ the message metadata for
|
# we make a single database query and load /all/ the message metadata for
|
||||||
# the new threads at once. (This is a performance optimization -it's about
|
# the new threads at once. (This is a performance optimization -it's about
|
||||||
# ~80msec faster than making 100 queries for 100 new thread ids separately.)
|
# ~80msec faster than making 100 queries for 100 new thread ids separately.)
|
||||||
Rx.Observable.zip([
|
$threadsResultSet.flatMapLatest (threadsResultSet) =>
|
||||||
$threadsResultSet,
|
|
||||||
$threadsResultSet.flatMapLatest (threadsResultSet) =>
|
|
||||||
missingIds = threadsResultSet.ids().filter (id) -> not $messagesResultSets[id]
|
missingIds = threadsResultSet.ids().filter (id) -> not $messagesResultSets[id]
|
||||||
return Rx.Observable.from([[]]) if missingIds.length is 0
|
if missingIds.length is 0
|
||||||
Rx.Observable.fromPromise(DatabaseStore.findAll(Message, threadId: missingIds))
|
promise = Promise.resolve([threadsResultSet, []])
|
||||||
])
|
else
|
||||||
|
promise = DatabaseStore.findAll(Message, threadId: missingIds).then (messages) =>
|
||||||
|
Promise.resolve([threadsResultSet, messages])
|
||||||
|
|
||||||
|
return Rx.Observable.fromPromise(promise)
|
||||||
|
|
||||||
# 3. when that finishes, we group the loaded messsages by threadId and create
|
# 3. when that finishes, we group the loaded messsages by threadId and create
|
||||||
# the missing observables. Creating a query subscription would normally load
|
# the missing observables. Creating a query subscription would normally load
|
||||||
|
|
Loading…
Reference in a new issue