Mailspring/app/internal_packages_disabled/plugins/lib/plugins-tabs-view.jsx

67 lines
1.4 KiB
React
Raw Normal View History

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