Mailspring/internal_packages/plugins/lib/plugins-tabs-view.jsx

69 lines
1.3 KiB
React
Raw Normal View History

import React from 'react';
import classNames from 'classnames';
import Tabs from './tabs';
import TabsStore from './tabs-store';
import PluginsActions from './plugins-actions';
class PluginsTabs extends React.Component {
static displayName = 'PluginsTabs';
static propTypes = {
'onChange': React.PropTypes.Func,
};
constructor() {
super();
this.state = this._getStateFromStores();
}
componentDidMount() {
this._unsubscribers = [];
this._unsubscribers.push(TabsStore.listen(this._onChange));
}
componentWillUnmount() {
this._unsubscribers.forEach(unsubscribe => unsubscribe());
}
static containerRequired = false;
static containerStyles = {
minWidth: 200,
maxWidth: 290,
};
_getStateFromStores() {
return {
tabIndex: TabsStore.tabIndex(),
};
}
_onChange = () => {
this.setState(this._getStateFromStores());
}
_renderItems() {
return Tabs.map(({name, key, icon}, idx) => {
const classes = classNames({
'tab': true,
'active': idx === this.state.tabIndex,
});
return (<li key={key} className={classes} onClick={() => PluginsActions.selectTabIndex(idx)}>{name}</li>);
});
}
render() {
return (
<ul className="plugins-view-tabs">
{this._renderItems()}
</ul>
);
}
}
export default PluginsTabs;