react-bootstrap
Version:
Bootstrap 3 components build with React
62 lines (53 loc) • 1.64 kB
JavaScript
define(
["./react-es6","./react-es6/lib/cx","exports"],
function(__dependency1__, __dependency2__, __exports__) {
"use strict";
/** @jsx React.DOM */
var React = __dependency1__["default"];
var classSet = __dependency2__["default"];
var MenuItem = React.createClass({displayName: 'MenuItem',
propTypes: {
header: React.PropTypes.bool,
divider: React.PropTypes.bool,
href: React.PropTypes.string,
title: React.PropTypes.string,
onSelect: React.PropTypes.func
},
getDefaultProps: function () {
return {
href: '#'
};
},
handleClick: function (e) {
if (this.props.onSelect) {
e.preventDefault();
this.props.onSelect(this.props.key);
}
},
renderAnchor: function () {
return (
React.DOM.a( {onClick:this.handleClick, href:this.props.href, title:this.props.title, tabIndex:"-1"},
this.props.children
)
);
},
render: function () {
var classes = {
'dropdown-header': this.props.header,
'divider': this.props.divider
};
var children = null;
if (this.props.header) {
children = this.props.children;
} else if (!this.props.divider) {
children = this.renderAnchor();
}
return this.transferPropsTo(
React.DOM.li( {role:"presentation", title:null, href:null, className:classSet(classes)},
children
)
);
}
});
__exports__["default"] = MenuItem;
});