2016-11-22 14:19:08 -06:00
|
|
|
import React from 'react';
|
|
|
|
import {Link} from './link.js';
|
|
|
|
|
2016-08-07 16:10:44 -04:00
|
|
|
var Header = React.createClass({
|
2016-08-07 18:13:17 -04:00
|
|
|
getInitialState: function() {
|
|
|
|
return {
|
2016-08-07 20:20:14 -04:00
|
|
|
title: "LBRY",
|
|
|
|
isScrolled: false
|
2016-08-07 18:13:17 -04:00
|
|
|
};
|
|
|
|
},
|
|
|
|
componentWillMount: function() {
|
|
|
|
new MutationObserver(function(mutations) {
|
2016-08-09 16:33:01 -04:00
|
|
|
this.setState({ title: mutations[0].target.textContent });
|
2016-08-07 18:13:17 -04:00
|
|
|
}.bind(this)).observe(
|
|
|
|
document.querySelector('title'),
|
|
|
|
{ subtree: true, characterData: true, childList: true }
|
|
|
|
);
|
|
|
|
},
|
2016-08-07 22:48:45 -04:00
|
|
|
componentDidMount: function() {
|
2016-08-07 20:20:14 -04:00
|
|
|
document.addEventListener('scroll', this.handleScroll);
|
|
|
|
},
|
2016-08-07 22:48:45 -04:00
|
|
|
componentWillUnmount: function() {
|
2016-08-07 20:20:14 -04:00
|
|
|
document.removeEventListener('scroll', this.handleScroll);
|
2016-08-07 22:48:45 -04:00
|
|
|
if (this.userTypingTimer)
|
|
|
|
{
|
|
|
|
clearTimeout(this.userTypingTimer);
|
|
|
|
}
|
2016-08-07 20:20:14 -04:00
|
|
|
},
|
2016-08-07 22:48:45 -04:00
|
|
|
handleScroll: function() {
|
2016-08-07 20:20:14 -04:00
|
|
|
this.setState({
|
2016-08-19 09:47:40 -04:00
|
|
|
isScrolled: document.body.scrollTop > 0
|
2016-08-07 20:20:14 -04:00
|
|
|
});
|
|
|
|
},
|
2016-08-07 20:57:12 -04:00
|
|
|
onQueryChange: function(event) {
|
|
|
|
|
|
|
|
if (this.userTypingTimer)
|
|
|
|
{
|
|
|
|
clearTimeout(this.userTypingTimer);
|
|
|
|
}
|
|
|
|
|
|
|
|
//@TODO: Switch to React.js timing
|
2016-08-07 22:48:45 -04:00
|
|
|
var searchTerm = event.target.value;
|
|
|
|
this.userTypingTimer = setTimeout(() => {
|
|
|
|
this.props.onSearch(searchTerm);
|
|
|
|
}, 800); // 800ms delay, tweak for faster/slower
|
2016-08-07 20:57:12 -04:00
|
|
|
|
|
|
|
},
|
2016-08-07 16:10:44 -04:00
|
|
|
render: function() {
|
|
|
|
return (
|
2016-08-27 10:12:56 -04:00
|
|
|
<header id="header" className={ (this.state.isScrolled ? 'header-scrolled' : 'header-unscrolled') + ' ' + (this.props.links ? 'header-with-subnav' : 'header-no-subnav') }>
|
|
|
|
<div className="header-top-bar">
|
|
|
|
<Link onClick={this.props.onOpenDrawer} icon="icon-bars" className="open-drawer-link" />
|
|
|
|
<h1>{ this.state.title }</h1>
|
|
|
|
<div className="header-search">
|
2017-01-12 22:36:03 -05:00
|
|
|
<input type="search" onChange={this.onQueryChange} defaultValue={this.props.initialQuery}
|
2016-08-27 10:12:56 -04:00
|
|
|
placeholder="Find movies, music, games, and more"/>
|
|
|
|
</div>
|
2016-08-07 22:48:45 -04:00
|
|
|
</div>
|
2016-08-27 10:12:56 -04:00
|
|
|
{
|
|
|
|
this.props.links ?
|
|
|
|
<SubHeader links={this.props.links} viewingPage={this.props.viewingPage} /> :
|
|
|
|
''
|
|
|
|
}
|
2016-08-07 16:10:44 -04:00
|
|
|
</header>
|
|
|
|
);
|
|
|
|
}
|
2016-08-27 10:12:56 -04:00
|
|
|
});
|
|
|
|
|
|
|
|
var SubHeader = React.createClass({
|
|
|
|
render: function() {
|
|
|
|
var links = [],
|
|
|
|
viewingUrl = '?' + this.props.viewingPage;
|
2017-01-12 22:36:03 -05:00
|
|
|
|
2016-08-27 10:12:56 -04:00
|
|
|
for (let link of Object.keys(this.props.links)) {
|
|
|
|
links.push(
|
|
|
|
<a href={link} key={link} className={ viewingUrl == link ? 'sub-header-selected' : 'sub-header-unselected' }>
|
|
|
|
{this.props.links[link]}
|
|
|
|
</a>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<nav className="sub-header">
|
|
|
|
{links}
|
|
|
|
</nav>
|
|
|
|
);
|
|
|
|
}
|
2016-11-22 14:19:08 -06:00
|
|
|
});
|
|
|
|
|
|
|
|
export default Header;
|