mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-23 00:19:58 +08:00
b10942a4b3
Summary: - Converts SearchQuerySubscription to ES6 to fix method overriding for `removeCallback` - Reports different usage metrics for search - Removes unecessary data source listener iniside ThreadListStore: - This listener focused the first thread on the list, which is actually unwanted (#1461) - It prevented QuerySubscriptions from being disposed promptly because of the remaining listener. They qould only be disposed until the subscription triggered once, which is not actually desired behavior (e.g. for SearchQuerySubscription) Test Plan: - Manual Reviewers: evan, bengotow Reviewed By: bengotow Differential Revision: https://phab.nylas.com/D2864
75 lines
3.1 KiB
CoffeeScript
75 lines
3.1 KiB
CoffeeScript
_ = require 'underscore'
|
|
Rx = require 'rx-lite'
|
|
|
|
{ObservableListDataSource,
|
|
DatabaseStore,
|
|
Message,
|
|
QueryResultSet,
|
|
QuerySubscription} = require 'nylas-exports'
|
|
|
|
_flatMapJoiningMessages = ($threadsResultSet) =>
|
|
# DatabaseView leverages `QuerySubscription` for threads /and/ for the
|
|
# messages on each thread, which are passed to out as `thread.metadata`.
|
|
|
|
$messagesResultSets = {}
|
|
|
|
# 2. when we receive a set of threads, we check to see if we have message
|
|
# observables for each thread. If threads have been added to the result set,
|
|
# 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
|
|
# ~80msec faster than making 100 queries for 100 new thread ids separately.)
|
|
Rx.Observable.zip([
|
|
$threadsResultSet,
|
|
$threadsResultSet.flatMapLatest (threadsResultSet) =>
|
|
missingIds = threadsResultSet.ids().filter (id) -> not $messagesResultSets[id]
|
|
return Rx.Observable.from([[]]) if missingIds.length is 0
|
|
Rx.Observable.fromPromise(DatabaseStore.findAll(Message, threadId: missingIds))
|
|
])
|
|
|
|
# 3. when that finishes, we group the loaded messsages by threadId and create
|
|
# the missing observables. Creating a query subscription would normally load
|
|
# an initial result set. To avoid that, we just hand new subscriptions the
|
|
# results we loaded in #2.
|
|
.flatMapLatest ([threadsResultSet, messagesForNewThreads]) =>
|
|
messagesGrouped = {}
|
|
for message in messagesForNewThreads
|
|
messagesGrouped[message.threadId] ?= []
|
|
messagesGrouped[message.threadId].push(message)
|
|
|
|
oldSets = $messagesResultSets
|
|
$messagesResultSets = {}
|
|
|
|
sets = threadsResultSet.ids().map (id) =>
|
|
$messagesResultSets[id] = oldSets[id] || _observableForThreadMessages(id, messagesGrouped[id])
|
|
$messagesResultSets[id]
|
|
sets.unshift(Rx.Observable.from([threadsResultSet]))
|
|
|
|
# 4. We use `combineLatest` to merge the message observables into a single
|
|
# stream (like Promise.all). When /any/ of them emit a new result set, we
|
|
# trigger.
|
|
Rx.Observable.combineLatest(sets)
|
|
|
|
.flatMapLatest ([threadsResultSet, messagesResultSets...]) =>
|
|
threadsWithMetadata = {}
|
|
threadsResultSet.models().map (thread, idx) ->
|
|
thread = new thread.constructor(thread)
|
|
thread.metadata = messagesResultSets[idx]?.models()
|
|
threadsWithMetadata[thread.id] = thread
|
|
|
|
Rx.Observable.from([QueryResultSet.setByApplyingModels(threadsResultSet, threadsWithMetadata)])
|
|
|
|
_observableForThreadMessages = (id, initialModels) ->
|
|
subscription = new QuerySubscription(DatabaseStore.findAll(Message, threadId: id), {
|
|
asResultSet: true,
|
|
initialModels: initialModels
|
|
})
|
|
Rx.Observable.fromNamedQuerySubscription('message-'+id, subscription)
|
|
|
|
|
|
class ThreadListDataSource extends ObservableListDataSource
|
|
constructor: (subscription) ->
|
|
$resultSetObservable = Rx.Observable.fromNamedQuerySubscription('thread-list', subscription)
|
|
$resultSetObservable = _flatMapJoiningMessages($resultSetObservable)
|
|
super($resultSetObservable, subscription.replaceRange.bind(subscription))
|
|
|
|
module.exports = ThreadListDataSource
|