UNPKG

3.5 kBJavaScriptView Raw
1'use strict';
2
3exports.__esModule = true;
4
5var _extends2 = require('babel-runtime/helpers/extends');
6
7var _extends3 = _interopRequireDefault(_extends2);
8
9var _objectWithoutProperties2 = require('babel-runtime/helpers/objectWithoutProperties');
10
11var _objectWithoutProperties3 = _interopRequireDefault(_objectWithoutProperties2);
12
13var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
14
15var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
16
17var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
18
19var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
20
21var _inherits2 = require('babel-runtime/helpers/inherits');
22
23var _inherits3 = _interopRequireDefault(_inherits2);
24
25var _classnames = require('classnames');
26
27var _classnames2 = _interopRequireDefault(_classnames);
28
29var _react = require('react');
30
31var _react2 = _interopRequireDefault(_react);
32
33var _propTypes = require('prop-types');
34
35var _propTypes2 = _interopRequireDefault(_propTypes);
36
37var _bootstrapUtils = require('./utils/bootstrapUtils');
38
39var _createChainedFunction = require('./utils/createChainedFunction');
40
41var _createChainedFunction2 = _interopRequireDefault(_createChainedFunction);
42
43function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
44
45var propTypes = {
46 onClick: _propTypes2.default.func,
47 /**
48 * The toggle content, if left empty it will render the default toggle (seen above).
49 */
50 children: _propTypes2.default.node
51};
52
53var contextTypes = {
54 $bs_navbar: _propTypes2.default.shape({
55 bsClass: _propTypes2.default.string,
56 expanded: _propTypes2.default.bool,
57 onToggle: _propTypes2.default.func.isRequired
58 })
59};
60
61var NavbarToggle = function (_React$Component) {
62 (0, _inherits3.default)(NavbarToggle, _React$Component);
63
64 function NavbarToggle() {
65 (0, _classCallCheck3.default)(this, NavbarToggle);
66 return (0, _possibleConstructorReturn3.default)(this, _React$Component.apply(this, arguments));
67 }
68
69 NavbarToggle.prototype.render = function render() {
70 var _props = this.props,
71 onClick = _props.onClick,
72 className = _props.className,
73 children = _props.children,
74 props = (0, _objectWithoutProperties3.default)(_props, ['onClick', 'className', 'children']);
75
76 var navbarProps = this.context.$bs_navbar || { bsClass: 'navbar' };
77
78 var buttonProps = (0, _extends3.default)({
79 type: 'button'
80 }, props, {
81 onClick: (0, _createChainedFunction2.default)(onClick, navbarProps.onToggle),
82 className: (0, _classnames2.default)(className, (0, _bootstrapUtils.prefix)(navbarProps, 'toggle'), !navbarProps.expanded && 'collapsed')
83 });
84
85 if (children) {
86 return _react2.default.createElement(
87 'button',
88 buttonProps,
89 children
90 );
91 }
92
93 return _react2.default.createElement(
94 'button',
95 buttonProps,
96 _react2.default.createElement(
97 'span',
98 { className: 'sr-only' },
99 'Toggle navigation'
100 ),
101 _react2.default.createElement('span', { className: 'icon-bar' }),
102 _react2.default.createElement('span', { className: 'icon-bar' }),
103 _react2.default.createElement('span', { className: 'icon-bar' })
104 );
105 };
106
107 return NavbarToggle;
108}(_react2.default.Component);
109
110NavbarToggle.propTypes = propTypes;
111NavbarToggle.contextTypes = contextTypes;
112
113exports.default = NavbarToggle;
114module.exports = exports['default'];
\No newline at end of file