Mailspring/app/internal_packages/send-later/lib/send-later-status.jsx

90 lines
2.2 KiB
React
Raw Normal View History

2017-09-27 02:33:08 +08:00
import React, { Component } from 'react';
import PropTypes from 'prop-types';
import moment from 'moment';
import { DateUtils, Actions, SyncbackMetadataTask, TaskQueue, SendDraftTask } from 'mailspring-exports';
2017-09-27 02:46:00 +08:00
import { RetinaImg } from 'mailspring-component-kit';
2017-09-27 02:33:08 +08:00
import { PLUGIN_ID } from './send-later-constants';
2017-09-27 02:33:08 +08:00
const { DATE_FORMAT_SHORT } = DateUtils;
export default class SendLaterStatus extends Component {
static displayName = 'SendLaterStatus';
static propTypes = {
draft: PropTypes.object,
};
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
});
}
componentWillReceiveProps(nextProps) {
this.setState(this.getStateFromStores(nextProps));
}
componentWillUnmount() {
if (this._unlisten) {
this._unlisten();
}
}
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-27 02:33:08 +08:00
getStateFromStores({ draft }) {
return {
2017-09-27 02:33:08 +08:00
task: TaskQueue.findTasks(
SendDraftTask,
{ headerMessageId: draft.headerMessageId },
{ includeCompleted: true }
).pop(),
};
}
render() {
const metadata = this.props.draft.metadataForPluginId(PLUGIN_ID);
if (!metadata || !metadata.expiration) {
2017-09-27 02:33:08 +08:00
return <span />;
}
2017-09-27 02:33:08 +08:00
const { expiration } = metadata;
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>
<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
);
}
}