Mailspring/app/internal_packages/thread-list/lib/thread-list-context-menu.es6

182 lines
4.2 KiB
Text
Raw Normal View History

2016-05-07 07:06:16 +08:00
/* eslint global-require: 0*/
2017-09-27 02:33:08 +08:00
import _ from 'underscore';
import {
Thread,
Actions,
Message,
TaskFactory,
DatabaseStore,
FocusedPerspectiveStore,
2017-09-27 02:33:08 +08:00
} from 'nylas-exports';
export default class ThreadListContextMenu {
2017-09-27 02:33:08 +08:00
constructor({ threadIds = [], accountIds = [] }) {
this.threadIds = threadIds;
this.accountIds = accountIds;
}
menuItemTemplate() {
return DatabaseStore.modelify(Thread, this.threadIds)
2017-09-27 02:33:08 +08:00
.then(threads => {
this.threads = threads;
return Promise.all([
this.replyItem(),
this.replyAllItem(),
this.forwardItem(),
{ type: 'separator' },
this.archiveItem(),
this.trashItem(),
this.markAsReadItem(),
this.starItem(),
]);
})
.then(menuItems => {
return _.filter(_.compact(menuItems), (item, index) => {
if ((index === 0 || index === menuItems.length - 1) && item.type === 'separator') {
return false;
}
return true;
});
});
}
replyItem() {
2017-09-27 02:33:08 +08:00
if (this.threadIds.length !== 1) {
return null;
}
return {
2017-09-27 02:33:08 +08:00
label: 'Reply',
click: () => {
Actions.composeReply({
threadId: this.threadIds[0],
popout: true,
type: 'reply',
behavior: 'prefer-existing-if-pristine',
});
},
2017-09-27 02:33:08 +08:00
};
}
replyAllItem() {
2016-05-07 07:06:16 +08:00
if (this.threadIds.length !== 1) {
return null;
}
2017-09-27 02:33:08 +08:00
return DatabaseStore.findBy(Message, { threadId: this.threadIds[0] })
.order(Message.attributes.date.descending())
.limit(1)
.then(message => {
if (message && message.canReplyAll()) {
return {
label: 'Reply All',
click: () => {
Actions.composeReply({
threadId: this.threadIds[0],
popout: true,
type: 'reply-all',
behavior: 'prefer-existing-if-pristine',
});
},
};
}
2017-09-27 02:33:08 +08:00
return null;
});
}
forwardItem() {
2017-09-27 02:33:08 +08:00
if (this.threadIds.length !== 1) {
return null;
}
return {
2017-09-27 02:33:08 +08:00
label: 'Forward',
click: () => {
2017-09-27 02:33:08 +08:00
Actions.composeForward({ threadId: this.threadIds[0], popout: true });
},
2017-09-27 02:33:08 +08:00
};
}
archiveItem() {
2017-09-27 02:33:08 +08:00
const perspective = FocusedPerspectiveStore.current();
const allowed = perspective.canArchiveThreads(this.threads);
if (!allowed) {
2017-09-27 02:33:08 +08:00
return null;
}
return {
2017-09-27 02:33:08 +08:00
label: 'Archive',
click: () => {
const tasks = TaskFactory.tasksForArchiving({
2017-09-27 02:33:08 +08:00
source: 'Context Menu: Thread List',
threads: this.threads,
2017-09-27 02:33:08 +08:00
});
Actions.queueTasks(tasks);
},
2017-09-27 02:33:08 +08:00
};
}
trashItem() {
2017-09-27 02:33:08 +08:00
const perspective = FocusedPerspectiveStore.current();
const allowed = perspective.canMoveThreadsTo(this.threads, 'trash');
if (!allowed) {
2017-09-27 02:33:08 +08:00
return null;
}
return {
2017-09-27 02:33:08 +08:00
label: 'Trash',
click: () => {
const tasks = TaskFactory.tasksForMovingToTrash({
2017-09-27 02:33:08 +08:00
source: 'Context Menu: Thread List',
threads: this.threads,
2017-09-27 02:33:08 +08:00
});
Actions.queueTasks(tasks);
},
2017-09-27 02:33:08 +08:00
};
}
markAsReadItem() {
const unread = this.threads.every(t => t.unread === false);
2017-09-27 02:33:08 +08:00
const dir = unread ? 'Unread' : 'Read';
return {
label: `Mark as ${dir}`,
click: () => {
2017-09-27 02:33:08 +08:00
Actions.queueTask(
TaskFactory.taskForInvertingUnread({
source: 'Context Menu: Thread List',
threads: this.threads,
})
);
},
2017-09-27 02:33:08 +08:00
};
}
starItem() {
const starred = this.threads.every(t => t.starred === false);
2017-09-27 02:33:08 +08:00
let dir = '';
let star = 'Star';
if (!starred) {
2017-09-27 02:33:08 +08:00
dir = 'Remove ';
star = this.threadIds.length > 1 ? 'Stars' : 'Star';
}
return {
label: `${dir}${star}`,
click: () => {
2017-09-27 02:33:08 +08:00
Actions.queueTask(
TaskFactory.taskForInvertingStarred({
source: 'Context Menu: Thread List',
threads: this.threads,
})
);
},
2017-09-27 02:33:08 +08:00
};
}
displayMenu() {
2017-09-27 02:33:08 +08:00
const { remote } = require('electron');
this.menuItemTemplate().then(template => {
remote.Menu.buildFromTemplate(template).popup(remote.getCurrentWindow());
});
}
}