mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-07 16:48:02 +08:00
115 lines
3 KiB
JavaScript
115 lines
3 KiB
JavaScript
import classNames from 'classnames';
|
|
import { React, PropTypes, Utils, DraftStore, ComponentRegistry } from 'mailspring-exports';
|
|
|
|
import MessageItem from './message-item';
|
|
|
|
export default class MessageItemContainer extends React.Component {
|
|
static displayName = 'MessageItemContainer';
|
|
|
|
static propTypes = {
|
|
thread: PropTypes.object.isRequired,
|
|
message: PropTypes.object.isRequired,
|
|
messages: PropTypes.array.isRequired,
|
|
collapsed: PropTypes.bool,
|
|
isMostRecent: PropTypes.bool,
|
|
isBeforeReplyArea: PropTypes.bool,
|
|
scrollTo: PropTypes.func,
|
|
};
|
|
|
|
constructor(props, context) {
|
|
super(props, context);
|
|
this.state = this._getStateFromStores();
|
|
}
|
|
|
|
componentDidMount() {
|
|
if (this.props.message.draft) {
|
|
this._unlisten = DraftStore.listen(this._onSendingStateChanged);
|
|
}
|
|
}
|
|
|
|
componentWillReceiveProps(newProps) {
|
|
this.setState(this._getStateFromStores(newProps));
|
|
}
|
|
|
|
shouldComponentUpdate(nextProps, nextState) {
|
|
return !Utils.isEqualReact(nextProps, this.props) || !Utils.isEqualReact(nextState, this.state);
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
if (this._unlisten) {
|
|
this._unlisten();
|
|
}
|
|
}
|
|
|
|
focus = () => {
|
|
this._messageComponent.focus();
|
|
};
|
|
|
|
_classNames() {
|
|
return classNames({
|
|
draft: this.props.message.draft,
|
|
unread: this.props.message.unread,
|
|
collapsed: this.props.collapsed,
|
|
'message-item-wrap': true,
|
|
'before-reply-area': this.props.isBeforeReplyArea,
|
|
});
|
|
}
|
|
|
|
_onSendingStateChanged = ({ headerMessageId }) => {
|
|
if (headerMessageId === this.props.message.headerMessageId) {
|
|
this.setState(this._getStateFromStores());
|
|
}
|
|
};
|
|
|
|
_getStateFromStores(props = this.props) {
|
|
return {
|
|
isSending: DraftStore.isSendingDraft(props.message.headerMessageId),
|
|
};
|
|
}
|
|
|
|
_renderMessage({ pending }) {
|
|
return (
|
|
<MessageItem
|
|
ref={cm => {
|
|
this._messageComponent = cm;
|
|
}}
|
|
pending={pending}
|
|
thread={this.props.thread}
|
|
message={this.props.message}
|
|
messages={this.props.messages}
|
|
className={this._classNames()}
|
|
collapsed={this.props.collapsed}
|
|
isMostRecent={this.props.isMostRecent}
|
|
/>
|
|
);
|
|
}
|
|
|
|
_renderComposer() {
|
|
const Composer = ComponentRegistry.findComponentsMatching({ role: 'Composer' })[0];
|
|
if (!Composer) {
|
|
return <span>No Composer Component Present</span>;
|
|
}
|
|
return (
|
|
<Composer
|
|
ref={cm => {
|
|
this._messageComponent = cm;
|
|
}}
|
|
headerMessageId={this.props.message.headerMessageId}
|
|
className={this._classNames()}
|
|
mode={'inline'}
|
|
threadId={this.props.thread.id}
|
|
scrollTo={this.props.scrollTo}
|
|
/>
|
|
);
|
|
}
|
|
|
|
render() {
|
|
if (this.state.isSending) {
|
|
return this._renderMessage({ pending: true });
|
|
}
|
|
if (this.props.message.draft && !this.props.collapsed) {
|
|
return this._renderComposer();
|
|
}
|
|
return this._renderMessage({ pending: false });
|
|
}
|
|
}
|