lbry-desktop/ui/js/component/menu.js

93 lines
2.4 KiB
JavaScript
Raw Normal View History

2016-11-22 21:19:08 +01:00
import React from 'react';
import {Icon} from './common.js';
2017-04-07 07:15:22 +02:00
import Link from 'component/link';
2016-11-22 21:19:08 +01:00
2017-05-17 10:10:25 +02:00
export class DropDownMenuItem extends React.Component {
static propTypes = {
href: React.PropTypes.string,
label: React.PropTypes.string,
icon: React.PropTypes.string,
onClick: React.PropTypes.func,
2017-05-17 10:10:25 +02:00
}
static defaultProps = {
iconPosition: 'left',
}
render() {
var icon = (this.props.icon ? <Icon icon={this.props.icon} fixed /> : null);
return (
<a className="menu__menu-item" onClick={this.props.onClick}
href={this.props.href || 'javascript:'} label={this.props.label}>
{this.props.iconPosition == 'left' ? icon : null}
{this.props.label}
{this.props.iconPosition == 'left' ? null : icon}
</a>
);
}
2017-05-17 10:10:25 +02:00
}
export class DropDownMenu extends React.Component {
constructor(props) {
super(props);
2017-05-17 10:10:25 +02:00
this._isWindowClickBound = false;
this._menuDiv = null;
2017-05-17 10:10:25 +02:00
this.state = {
menuOpen: false,
};
2017-05-17 10:10:25 +02:00
}
componentWillUnmount() {
if (this._isWindowClickBound) {
window.removeEventListener('click', this.handleWindowClick, false);
}
2017-05-17 10:10:25 +02:00
}
handleMenuIconClick(e) {
this.setState({
menuOpen: !this.state.menuOpen,
});
if (!this.state.menuOpen && !this._isWindowClickBound) {
this._isWindowClickBound = true;
window.addEventListener('click', this.handleWindowClick, false);
e.stopPropagation();
}
return false;
2017-05-17 10:10:25 +02:00
}
handleMenuClick(e) {
// Event bubbles up to the menu after a link is clicked
this.setState({
menuOpen: false,
});
2017-05-17 10:10:25 +02:00
}
handleWindowClick(e) {
if (this.state.menuOpen &&
(!this._menuDiv || !this._menuDiv.contains(e.target))) {
this.setState({
menuOpen: false
});
}
2017-05-17 10:10:25 +02:00
}
render() {
if (!this.state.menuOpen && this._isWindowClickBound) {
this._isWindowClickBound = false;
window.removeEventListener('click', this.handleWindowClick, false);
}
return (
<div className="menu-container">
<Link ref={(span) => this._menuButton = span} button="text" icon="icon-ellipsis-v" onClick={(event) => { this.handleMenuIconClick(event) }} />
{this.state.menuOpen
? <div ref={(div) => this._menuDiv = div} className="menu" onClick={(event) => { this.handleMenuClick(event) }}>
{this.props.children}
</div>
: null}
</div>
);
}
2017-05-17 10:10:25 +02:00
}