import { localized, React, ReactDOM, Actions, PropTypes } from 'mailspring-exports';
import { RetinaImg } from 'mailspring-component-kit';
import OpenTrackingMessagePopover from './open-tracking-message-popover';
import { PLUGIN_ID } from './open-tracking-constants';
export default class OpenTrackingMessageStatus extends React.Component {
static displayName = 'OpenTrackingMessageStatus';
static propTypes = {
message: PropTypes.object.isRequired,
};
static containerStyles = {
paddingTop: 4,
};
constructor(props) {
super(props);
this.state = this._getStateFromMessage(props.message);
}
componentWillReceiveProps(nextProps) {
this.setState(this._getStateFromMessage(nextProps.message));
}
onMouseDown = () => {
const rect = ReactDOM.findDOMNode(this).getBoundingClientRect();
Actions.openPopover(
,
{ originRect: rect, direction: 'down' }
);
};
_getStateFromMessage(message) {
const metadata = message.metadataForPluginId(PLUGIN_ID);
if (!metadata || metadata.open_count == null) {
return {
hasMetadata: false,
openCount: null,
opened: false,
};
}
return {
hasMetadata: true,
openCount: metadata.open_count,
opened: metadata.open_count > 0,
};
}
renderImage() {
return (
);
}
render() {
if (!this.state.hasMetadata) return false;
const noun = this.state.openCount === 1 ? localized('Open') : localized('Opens');
let count = this.state.openCount;
if (this.state.openCount > 999) {
count = '999+';
}
const text = this.state.opened ? `${count} ${noun.toLocaleLowerCase()}` : localized('No opens');
return (
{this.renderImage()} {text}
);
}
}