2018-01-24 09:35:09 +08:00
|
|
|
const MailspringStore = require('mailspring-store').default;
|
|
|
|
const {
|
|
|
|
Rx,
|
|
|
|
Message,
|
|
|
|
OutboxStore,
|
|
|
|
AccountStore,
|
|
|
|
MutableQueryResultSet,
|
|
|
|
MutableQuerySubscription,
|
|
|
|
ObservableListDataSource,
|
|
|
|
FocusedPerspectiveStore,
|
|
|
|
DatabaseStore,
|
|
|
|
} = require('mailspring-exports');
|
|
|
|
const { ListTabular } = require('mailspring-component-kit');
|
|
|
|
|
|
|
|
class DraftListStore extends MailspringStore {
|
|
|
|
constructor() {
|
|
|
|
super();
|
2018-01-29 23:53:49 +08:00
|
|
|
this.listenTo(FocusedPerspectiveStore, this._onPerspectiveChanged);
|
2018-01-24 09:35:09 +08:00
|
|
|
this._createListDataSource();
|
|
|
|
}
|
|
|
|
|
|
|
|
dataSource = () => {
|
|
|
|
return this._dataSource;
|
|
|
|
};
|
|
|
|
|
|
|
|
selectionObservable = () => {
|
|
|
|
return Rx.Observable.fromListSelection(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
// Inbound Events
|
|
|
|
|
|
|
|
_onPerspectiveChanged = () => {
|
|
|
|
this._createListDataSource();
|
|
|
|
};
|
|
|
|
|
|
|
|
// Internal
|
|
|
|
|
|
|
|
_createListDataSource = () => {
|
|
|
|
const mailboxPerspective = FocusedPerspectiveStore.current();
|
|
|
|
|
2018-01-29 23:53:49 +08:00
|
|
|
if (this._dataSource) {
|
|
|
|
this._dataSource.cleanup();
|
|
|
|
this._dataSource = null;
|
|
|
|
}
|
|
|
|
|
2018-01-24 09:35:09 +08:00
|
|
|
if (mailboxPerspective.drafts) {
|
|
|
|
const query = DatabaseStore.findAll(Message)
|
|
|
|
.include(Message.attributes.body)
|
|
|
|
.order(Message.attributes.date.descending())
|
|
|
|
.where({ draft: true })
|
|
|
|
.page(0, 1);
|
|
|
|
|
|
|
|
// Adding a "account_id IN (a,b,c)" clause to our query can result in a full
|
|
|
|
// table scan. Don't add the where clause if we know we want results from all.
|
|
|
|
if (mailboxPerspective.accountIds.length < AccountStore.accounts().length) {
|
|
|
|
query.where({ accountId: mailboxPerspective.accountIds });
|
|
|
|
}
|
|
|
|
|
|
|
|
const subscription = new MutableQuerySubscription(query, { emitResultSet: true });
|
|
|
|
let $resultSet = Rx.Observable.fromNamedQuerySubscription('draft-list', subscription);
|
|
|
|
$resultSet = Rx.Observable.combineLatest(
|
|
|
|
[$resultSet, Rx.Observable.fromStore(OutboxStore)],
|
|
|
|
(resultSet, outbox) => {
|
|
|
|
// Generate a new result set that includes additional information on
|
|
|
|
// the draft objects. This is similar to what we do in the thread-list,
|
|
|
|
// where we set thread.__messages to the message array.
|
|
|
|
const resultSetWithTasks = new MutableQueryResultSet(resultSet);
|
|
|
|
|
|
|
|
// TODO BG modelWithId: task.headerMessageId does not work
|
|
|
|
mailboxPerspective.accountIds.forEach(aid => {
|
|
|
|
OutboxStore.itemsForAccount(aid).forEach(task => {
|
|
|
|
let draft = resultSet.modelWithId(task.headerMessageId);
|
|
|
|
if (draft) {
|
|
|
|
draft = draft.clone();
|
|
|
|
draft.uploadTaskId = task.id;
|
|
|
|
draft.uploadProgress = task.progress;
|
|
|
|
resultSetWithTasks.updateModel(draft);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
return resultSetWithTasks.immutableClone();
|
|
|
|
}
|
|
|
|
);
|
|
|
|
|
|
|
|
this._dataSource = new ObservableListDataSource($resultSet, subscription.replaceRange);
|
|
|
|
} else {
|
|
|
|
this._dataSource = new ListTabular.DataSource.Empty();
|
|
|
|
}
|
|
|
|
|
|
|
|
this.trigger(this);
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = new DraftListStore();
|