import {React, ReactDOM, Actions} from 'nylas-exports';
import {RetinaImg} from 'nylas-component-kit';
import OpenTrackingMessagePopover from './open-tracking-message-popover';
import {PLUGIN_ID} from './open-tracking-constants';
export default class OpenTrackingIcon extends React.Component {
static displayName = 'OpenTrackingIcon';
static propTypes = {
thread: React.PropTypes.object.isRequired,
};
constructor(props) {
super(props);
this.state = this._getStateFromThread(props.thread)
}
componentWillReceiveProps(newProps) {
this.setState(this._getStateFromThread(newProps.thread));
}
onMouseDown = () => {
const rect = ReactDOM.findDOMNode(this).getBoundingClientRect();
Actions.openPopover(
,
{originRect: rect, direction: 'down'}
)
}
_getStateFromThread(thread) {
const messages = thread.__messages || []
let lastMessage = null;
for (let i = messages.length - 1; i >= 0; i--) {
if (!messages[i].draft) {
lastMessage = messages[i];
break;
}
}
if (!lastMessage) {
return {
message: null,
opened: false,
openCount: null,
hasMetadata: false,
};
}
const lastMessageMeta = lastMessage.metadataForPluginId(PLUGIN_ID);
const hasMetadata = lastMessageMeta != null && lastMessageMeta.open_count != null;
return {
message: lastMessage,
opened: hasMetadata && lastMessageMeta.open_count > 0,
openCount: hasMetadata ? lastMessageMeta.open_count : null,
hasMetadata: hasMetadata,
};
}
_renderImage() {
return (
);
}
render() {
if (!this.state.hasMetadata) return ;
const openedTitle = `${this.state.openCount} open${this.state.openCount === 1 ? "" : "s"}`;
const title = this.state.opened ? openedTitle : "This message has not been opened";
return (
{this._renderImage()}
);
}
}