UNPKG

3.37 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 _react = require('react');
26
27var _react2 = _interopRequireDefault(_react);
28
29var _propTypes = require('prop-types');
30
31var _propTypes2 = _interopRequireDefault(_propTypes);
32
33var _classnames = require('classnames');
34
35var _classnames2 = _interopRequireDefault(_classnames);
36
37var _Button = require('./Button');
38
39var _Button2 = _interopRequireDefault(_Button);
40
41var _SafeAnchor = require('./SafeAnchor');
42
43var _SafeAnchor2 = _interopRequireDefault(_SafeAnchor);
44
45var _bootstrapUtils = require('./utils/bootstrapUtils');
46
47function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
48
49var propTypes = {
50 noCaret: _propTypes2.default.bool,
51 open: _propTypes2.default.bool,
52 title: _propTypes2.default.string,
53 useAnchor: _propTypes2.default.bool
54};
55
56var defaultProps = {
57 open: false,
58 useAnchor: false,
59 bsRole: 'toggle'
60};
61
62var DropdownToggle = function (_React$Component) {
63 (0, _inherits3.default)(DropdownToggle, _React$Component);
64
65 function DropdownToggle() {
66 (0, _classCallCheck3.default)(this, DropdownToggle);
67 return (0, _possibleConstructorReturn3.default)(this, _React$Component.apply(this, arguments));
68 }
69
70 DropdownToggle.prototype.render = function render() {
71 var _props = this.props,
72 noCaret = _props.noCaret,
73 open = _props.open,
74 useAnchor = _props.useAnchor,
75 bsClass = _props.bsClass,
76 className = _props.className,
77 children = _props.children,
78 props = (0, _objectWithoutProperties3.default)(_props, ['noCaret', 'open', 'useAnchor', 'bsClass', 'className', 'children']);
79
80
81 delete props.bsRole;
82
83 var Component = useAnchor ? _SafeAnchor2.default : _Button2.default;
84 var useCaret = !noCaret;
85
86 // This intentionally forwards bsSize and bsStyle (if set) to the
87 // underlying component, to allow it to render size and style variants.
88
89 // FIXME: Should this really fall back to `title` as children?
90
91 return _react2.default.createElement(
92 Component,
93 (0, _extends3.default)({}, props, {
94 role: 'button',
95 className: (0, _classnames2.default)(className, bsClass),
96 'aria-haspopup': true,
97 'aria-expanded': open
98 }),
99 children || props.title,
100 useCaret && ' ',
101 useCaret && _react2.default.createElement('span', { className: 'caret' })
102 );
103 };
104
105 return DropdownToggle;
106}(_react2.default.Component);
107
108DropdownToggle.propTypes = propTypes;
109DropdownToggle.defaultProps = defaultProps;
110
111exports.default = (0, _bootstrapUtils.bsClass)('dropdown-toggle', DropdownToggle);
112module.exports = exports['default'];
\No newline at end of file