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} ); } }