2018-09-20 02:19:11 +00:00
|
|
|
import React from 'react';
|
2018-10-16 10:19:51 +00:00
|
|
|
import PropTypes from 'prop-types';
|
2018-09-20 02:19:11 +00:00
|
|
|
import Logo from './logo';
|
|
|
|
import MainSideNav from './main-side-nav';
|
|
|
|
import SideNavFooter from './side-nav-footer';
|
|
|
|
|
2018-10-16 10:19:51 +00:00
|
|
|
const propTypes = {
|
|
|
|
isSidePanelClosed: PropTypes.bool.isRequired,
|
2018-12-06 03:28:16 +00:00
|
|
|
currentTab: PropTypes.oneOfType([PropTypes.string, PropTypes.number]).isRequired,
|
2018-10-16 10:19:51 +00:00
|
|
|
onCloseSidePanel: PropTypes.func.isRequired,
|
2018-11-22 09:00:23 +00:00
|
|
|
tabItemClick: PropTypes.func.isRequired,
|
2018-10-16 10:19:51 +00:00
|
|
|
};
|
2018-09-20 02:19:11 +00:00
|
|
|
|
|
|
|
class SidePanel extends React.Component {
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return (
|
2018-09-25 01:13:06 +00:00
|
|
|
<div className={`side-panel ${this.props.isSidePanelClosed ? '' : 'left-zero'}`}>
|
2018-09-20 02:19:11 +00:00
|
|
|
<div className="side-panel-north">
|
2018-09-25 01:13:06 +00:00
|
|
|
<Logo onCloseSidePanel={this.props.onCloseSidePanel}/>
|
2018-09-20 02:19:11 +00:00
|
|
|
</div>
|
|
|
|
<div className="side-panel-center">
|
2024-03-25 09:22:01 +00:00
|
|
|
<MainSideNav tabItemClick={this.props.tabItemClick} currentTab={this.props.currentTab} />
|
2018-09-20 02:19:11 +00:00
|
|
|
</div>
|
|
|
|
<div className="side-panel-footer">
|
|
|
|
<SideNavFooter />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-16 10:19:51 +00:00
|
|
|
SidePanel.propTypes = propTypes;
|
|
|
|
|
2018-09-20 02:19:11 +00:00
|
|
|
export default SidePanel;
|