2017-09-27 02:33:08 +08:00
|
|
|
import React, { Component } from 'react';
|
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
import moment from 'moment';
|
2017-09-27 02:42:18 +08:00
|
|
|
import { DateUtils, Actions, SyncbackMetadataTask, TaskQueue, SendDraftTask } from 'mailspring-exports';
|
2017-09-27 02:33:08 +08:00
|
|
|
import { RetinaImg } from 'nylas-component-kit';
|
|
|
|
import { PLUGIN_ID } from './send-later-constants';
|
2017-09-07 07:19:48 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
const { DATE_FORMAT_SHORT } = DateUtils;
|
2017-09-07 07:19:48 +08:00
|
|
|
|
|
|
|
export default class SendLaterStatus extends Component {
|
|
|
|
static displayName = 'SendLaterStatus';
|
|
|
|
|
|
|
|
static propTypes = {
|
|
|
|
draft: PropTypes.object,
|
|
|
|
};
|
|
|
|
|
2017-09-26 13:35:35 +08:00
|
|
|
constructor(props) {
|
|
|
|
super(props);
|
|
|
|
this.state = this.getStateFromStores(props);
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
|
|
|
this._unlisten = TaskQueue.listen(() => {
|
|
|
|
this.setState(this.getStateFromStores(this.props));
|
2017-09-27 02:33:08 +08:00
|
|
|
});
|
2017-09-26 13:35:35 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
componentWillReceiveProps(nextProps) {
|
|
|
|
this.setState(this.getStateFromStores(nextProps));
|
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
if (this._unlisten) {
|
|
|
|
this._unlisten();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-07 07:19:48 +08:00
|
|
|
onCancelSendLater = () => {
|
2017-09-27 02:33:08 +08:00
|
|
|
Actions.queueTask(
|
|
|
|
new SyncbackMetadataTask({
|
|
|
|
model: this.props.draft,
|
|
|
|
accountId: this.props.draft.accountId,
|
|
|
|
pluginId: PLUGIN_ID,
|
|
|
|
value: { expiration: null },
|
|
|
|
})
|
|
|
|
);
|
2017-09-07 07:19:48 +08:00
|
|
|
};
|
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
getStateFromStores({ draft }) {
|
2017-09-26 13:35:35 +08:00
|
|
|
return {
|
2017-09-27 02:33:08 +08:00
|
|
|
task: TaskQueue.findTasks(
|
|
|
|
SendDraftTask,
|
|
|
|
{ headerMessageId: draft.headerMessageId },
|
|
|
|
{ includeCompleted: true }
|
|
|
|
).pop(),
|
|
|
|
};
|
2017-09-26 13:35:35 +08:00
|
|
|
}
|
|
|
|
|
2017-09-07 07:19:48 +08:00
|
|
|
render() {
|
2017-09-26 13:35:35 +08:00
|
|
|
const metadata = this.props.draft.metadataForPluginId(PLUGIN_ID);
|
|
|
|
if (!metadata || !metadata.expiration) {
|
2017-09-27 02:33:08 +08:00
|
|
|
return <span />;
|
2017-09-07 07:19:48 +08:00
|
|
|
}
|
2017-09-26 13:35:35 +08:00
|
|
|
|
2017-09-27 02:33:08 +08:00
|
|
|
const { expiration } = metadata;
|
2017-09-26 13:35:35 +08:00
|
|
|
|
|
|
|
let label = null;
|
|
|
|
if (expiration > new Date(Date.now() + 60 * 1000)) {
|
|
|
|
label = `Scheduled for ${DateUtils.format(moment(expiration), DATE_FORMAT_SHORT)}`;
|
|
|
|
} else {
|
|
|
|
label = `Sending in a few seconds...`;
|
|
|
|
if (this.state.task) {
|
|
|
|
label = `Sending now...`;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div className="send-later-status">
|
2017-09-27 02:33:08 +08:00
|
|
|
<span className="time">{label}</span>
|
2017-09-26 13:35:35 +08:00
|
|
|
<RetinaImg
|
|
|
|
name="image-cancel-button.png"
|
|
|
|
title="Cancel Send Later"
|
|
|
|
onClick={this.onCancelSendLater}
|
|
|
|
mode={RetinaImg.Mode.ContentPreserve}
|
|
|
|
/>
|
|
|
|
</div>
|
2017-09-27 02:33:08 +08:00
|
|
|
);
|
2017-09-07 07:19:48 +08:00
|
|
|
}
|
|
|
|
}
|