mirror of
https://github.com/Stremio/stremio-web.git
synced 2026-03-23 16:17:46 +00:00
77 lines
2.5 KiB
JavaScript
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;
|