1 | 'use strict';
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 |
|
7 | var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
|
8 |
|
9 | var _react = require('react');
|
10 |
|
11 | var _react2 = _interopRequireDefault(_react);
|
12 |
|
13 | var _classnames = require('classnames');
|
14 |
|
15 | var _classnames2 = _interopRequireDefault(_classnames);
|
16 |
|
17 | var _utils = require('./utils');
|
18 |
|
19 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
20 |
|
21 | function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
22 |
|
23 | function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
|
24 |
|
25 | var propTypes = {
|
26 | light: _react.PropTypes.bool,
|
27 | inverse: _react.PropTypes.bool,
|
28 | full: _react.PropTypes.bool,
|
29 | fixed: _react.PropTypes.string,
|
30 | sticky: _react.PropTypes.string,
|
31 | color: _react.PropTypes.string,
|
32 | role: _react.PropTypes.string,
|
33 | tag: _react.PropTypes.oneOfType([_react.PropTypes.func, _react.PropTypes.string]),
|
34 | className: _react.PropTypes.string,
|
35 | cssModule: _react.PropTypes.object,
|
36 | toggleable: _react.PropTypes.oneOfType([_react.PropTypes.bool, _react.PropTypes.string])
|
37 | };
|
38 |
|
39 | var defaultProps = {
|
40 | tag: 'nav',
|
41 | role: 'navigation',
|
42 | toggleable: false
|
43 | };
|
44 |
|
45 | var getToggleableClass = function getToggleableClass(toggleable) {
|
46 | if (toggleable === false) {
|
47 | return false;
|
48 | } else if (toggleable === true || toggleable === 'xs') {
|
49 | return 'navbar-toggleable';
|
50 | }
|
51 |
|
52 | return 'navbar-toggleable-' + toggleable;
|
53 | };
|
54 |
|
55 | var Navbar = function Navbar(props) {
|
56 | var _classNames;
|
57 |
|
58 | var toggleable = props.toggleable,
|
59 | className = props.className,
|
60 | cssModule = props.cssModule,
|
61 | light = props.light,
|
62 | inverse = props.inverse,
|
63 | full = props.full,
|
64 | fixed = props.fixed,
|
65 | sticky = props.sticky,
|
66 | color = props.color,
|
67 | Tag = props.tag,
|
68 | attributes = _objectWithoutProperties(props, ['toggleable', 'className', 'cssModule', 'light', 'inverse', 'full', 'fixed', 'sticky', 'color', 'tag']);
|
69 |
|
70 | var classes = (0, _utils.mapToCssModules)((0, _classnames2.default)(className, 'navbar', getToggleableClass(toggleable), (_classNames = {
|
71 | 'navbar-light': light,
|
72 | 'navbar-inverse': inverse
|
73 | }, _defineProperty(_classNames, 'bg-' + color, color), _defineProperty(_classNames, 'navbar-full', full), _defineProperty(_classNames, 'fixed-' + fixed, fixed), _defineProperty(_classNames, 'sticky-' + sticky, sticky), _classNames)), cssModule);
|
74 |
|
75 | return _react2.default.createElement(Tag, _extends({}, attributes, { className: classes }));
|
76 | };
|
77 |
|
78 | Navbar.propTypes = propTypes;
|
79 | Navbar.defaultProps = defaultProps;
|
80 |
|
81 | exports.default = Navbar; |
\ | No newline at end of file |