generator-bingo-dig-h5
Version:
Bingo-dig-h5 generator by BINGO.DIG
89 lines (73 loc) • 2.47 kB
JSX
var React = require('react');
var Classable = require('../mixins/classable');
var ClickAwayable = require('../mixins/click-awayable');
var Paper = require('./paper');
var IconButton = require('./icon-button');
var DropDownContainer = require('./drop-down-container');
var DropDownButton = React.createClass({
mixins: [Classable, ClickAwayable],
propTypes: {
iconClassName: React.PropTypes.string.isRequired,
closeOnMenuItemClick: React.PropTypes.bool,
menuPositon: React.PropTypes.oneOf(['leftBottom', 'RightBottom']),
tooltip: React.PropTypes.string,
touch: React.PropTypes.bool,
hasCounts: React.PropTypes.bool,
counts: React.PropTypes.number,
midSize: React.PropTypes.bool,
dropDownContainerWidth: React.PropTypes.number
},
getInitialState: function() {
return {
open: false
}
},
getDefaultProps: function() {
return {
closeOnMenuItemClick: true,
menuPositon: 'leftBottom'
}
},
componentClickAway: function() {
this.setState({ open: false });
},
render: function() {
var classes = this.getClasses('dig-drop-down-button', {
'mid-size': this.props.midSize,
'dig-open': this.state.open,
'dig-leftBottom': this.props.menuPositon == "leftBottom",
'dig-RightBottom': this.props.menuPositon == "RightBottom"
});
var iconButtonProps = {
iconClassName: this.props.iconClassName,
midSize: this.props.midSize,
hasCounts: this.props.hasCounts,
counts: this.props.counts,
tooltip: this.props.tooltip,
};
var icon;
if (this.props.iconClassName) {
icon = (<IconButton {...iconButtonProps}/>)
}
return (
<div className={classes}>
<div className="dig-drop-down-control" onClick={this._onControlClick}>
{icon}
</div>
<DropDownContainer visible={this.state.open} zDepth={1} Width={this.props.dropDownContainerWidth}>
{this.props.children}
</DropDownContainer>
</div>
);
},
_onControlClick: function(e) {
this.setState({ open: !this.state.open });
},
_onMenuItemClick: function(e, key, payload) {
if (this.props.onChange) this.props.onChange(e, key, payload);
if (this.props.closeOnMenuItemClick) {
this.setState({ open: false });
}
}
});
module.exports = DropDownButton;