2017-09-07 07:19:48 +08:00
|
|
|
import React from 'react';
|
2017-09-27 02:42:18 +08:00
|
|
|
import { Actions, ReactDOM } from 'mailspring-exports';
|
2017-09-27 02:46:00 +08:00
|
|
|
import { RetinaImg } from 'mailspring-component-kit';
|
2017-09-07 07:19:48 +08:00
|
|
|
|
|
|
|
import ActivityList from './activity-list';
|
2017-11-08 03:05:25 +08:00
|
|
|
import ActivityEventStore from '../activity-event-store';
|
2017-09-07 07:19:48 +08:00
|
|
|
|
|
|
|
class ActivityListButton extends React.Component {
|
|
|
|
static displayName = 'ActivityListButton';
|
|
|
|
|
|
|
|
constructor() {
|
|
|
|
super();
|
|
|
|
this.state = this._getStateFromStores();
|
|
|
|
}
|
|
|
|
|
|
|
|
componentDidMount() {
|
2017-11-08 03:05:25 +08:00
|
|
|
this._unsub = ActivityEventStore.listen(this._onDataChanged);
|
2017-09-07 07:19:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
componentWillUnmount() {
|
|
|
|
this._unsub();
|
|
|
|
}
|
|
|
|
|
|
|
|
onClick = () => {
|
|
|
|
const buttonRect = ReactDOM.findDOMNode(this).getBoundingClientRect();
|
2017-09-27 02:33:08 +08:00
|
|
|
Actions.openPopover(<ActivityList />, { originRect: buttonRect, direction: 'down' });
|
|
|
|
};
|
2017-09-07 07:19:48 +08:00
|
|
|
|
|
|
|
_onDataChanged = () => {
|
|
|
|
this.setState(this._getStateFromStores());
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2017-09-07 07:19:48 +08:00
|
|
|
|
|
|
|
_getStateFromStores() {
|
|
|
|
return {
|
2017-11-08 03:05:25 +08:00
|
|
|
unreadCount: ActivityEventStore.unreadCount(),
|
2017-09-27 02:33:08 +08:00
|
|
|
};
|
2017-09-07 07:19:48 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
2017-09-27 02:33:08 +08:00
|
|
|
let unreadCountClass = 'unread-count';
|
|
|
|
let iconClass = 'activity-toolbar-icon';
|
2017-09-07 07:19:48 +08:00
|
|
|
if (this.state.unreadCount) {
|
2017-09-27 02:33:08 +08:00
|
|
|
unreadCountClass += ' active';
|
|
|
|
iconClass += ' unread';
|
2017-09-07 07:19:48 +08:00
|
|
|
}
|
|
|
|
return (
|
2017-09-27 02:33:08 +08:00
|
|
|
<div tabIndex={-1} className="toolbar-activity" title="View activity" onClick={this.onClick}>
|
|
|
|
<div className={unreadCountClass}>{this.state.unreadCount}</div>
|
2017-09-07 07:19:48 +08:00
|
|
|
<RetinaImg
|
|
|
|
name="icon-toolbar-activity.png"
|
|
|
|
className={iconClass}
|
|
|
|
mode={RetinaImg.Mode.ContentIsMask}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default ActivityListButton;
|