/* * Copyright 2007-2017 Charles du Jeu - Abstrium SAS * This file is part of Pydio. * * Pydio is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Pydio is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with Pydio. If not, see . * * The latest code can be found at . */ const React = require('react') const {IconButton, Popover} = require('material-ui') class IconButtonPopover extends React.Component{ constructor(props, context){ super(props, context); this.state = {showPopover: false}; } showPopover(event){ this.setState({ showPopover: true, anchor: event.currentTarget }) } render(){ return ( {this.setState({showPopover: false})}} useLayerForClickAway={false} > {this.props.popoverContent} ); } } IconButtonPopover.propTypes = { buttonTitle: React.PropTypes.string.isRequired, buttonClassName: React.PropTypes.string.isRequired, className: React.PropTypes.string, direction: React.PropTypes.oneOf(['right', 'left']), popoverContent: React.PropTypes.object.isRequired } export default IconButtonPopover