mirror of
https://github.com/twisterarmy/twister-react.git
synced 2025-01-14 00:48:17 +00:00
39 lines
1.1 KiB
JavaScript
Executable File
39 lines
1.1 KiB
JavaScript
Executable File
var React = require('react');
|
|
|
|
var Button = require('react-bootstrap/lib/Button');
|
|
var LinkMixin = require('./LinkMixin');
|
|
|
|
var ButtonLink = React.createClass({displayName: "ButtonLink",
|
|
mixins: [
|
|
LinkMixin
|
|
],
|
|
contextTypes: {
|
|
router: React.PropTypes.func.isRequired
|
|
},
|
|
|
|
render: function () {
|
|
var $__0=
|
|
|
|
|
|
|
|
|
|
this.props,to=$__0.to,params=$__0.params,query=$__0.query,active=$__0.active,props=(function(source, exclusion) {var rest = {};var hasOwn = Object.prototype.hasOwnProperty;if (source == null) {throw new TypeError();}for (var key in source) {if (hasOwn.call(source, key) && !hasOwn.call(exclusion, key)) {rest[key] = source[key];}}return rest;})($__0,{to:1,params:1,query:1,active:1});
|
|
|
|
if (this.props.active === undefined) {
|
|
active = this.context.router.isActive(to, params, query);
|
|
}
|
|
|
|
return (
|
|
React.createElement(Button, React.__spread({}, props,
|
|
{href: this.getHref(),
|
|
active: active,
|
|
onClick: this.handleRouteTo,
|
|
ref: "button"}),
|
|
this.props.children
|
|
)
|
|
);
|
|
}
|
|
});
|
|
|
|
module.exports = ButtonLink;
|