stremio-web/src/common/NavBar/NavBar.js
2019-05-13 15:32:45 +03:00

77 lines
2.5 KiB
JavaScript

const React = require('react');
const classnames = require('classnames');
const PropTypes = require('prop-types');
const NavBarButton = require('./NavBarButton');
const SearchBar = require('./SearchBar');
const UserMenu = require('./UserMenu');
const styles = require('./styles');
const NavBar = React.memo(({ className, backButton, tabs, title, searchBar, userMenu }) => {
const onBackButtonClick = React.useCallback(() => {
window.history.back();
}, []);
return (
<nav className={classnames(className, styles['nav-bar'])}>
{
backButton ?
<NavBarButton
className={styles['back-button']}
icon={'ic_back_ios'}
label={'back'}
onClick={onBackButtonClick}
/>
:
null
}
{
Array.isArray(tabs) && tabs.length > 0 ?
<div className={styles['nav-tabs-container']}>
{tabs.map(({ href, icon, label }) => (
<NavBarButton
key={href}
className={styles['nav-tab-button']}
href={href}
icon={icon}
label={label}
/>
))}
</div>
:
<h2 className={styles['title']}>{title}</h2>
}
{
searchBar ?
<React.Fragment>
<div className={styles['spacing']} />
<SearchBar className={styles['search-bar']} />
<div className={styles['spacing']} />
</React.Fragment>
:
null
}
{
userMenu ?
<UserMenu className={styles['user-menu']} />
:
null
}
</nav>
);
});
NavBar.displayName = 'NavBar';
NavBar.propTypes = {
className: PropTypes.string,
backButton: PropTypes.bool,
tabs: PropTypes.arrayOf(PropTypes.exact({
icon: PropTypes.string.isRequired,
label: PropTypes.string.isRequired,
href: PropTypes.string.isRequired
})),
title: PropTypes.string,
searchBar: PropTypes.bool,
userMenu: PropTypes.bool
};
module.exports = NavBar;