UNPKG

react-toolbox

Version:

A set of React components implementing Google's Material Design specification with the power of CSS Modules.

92 lines (69 loc) 2.85 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.Navigation = exports.navigationFactory = undefined; 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; }; var _react = require('react'); var _react2 = _interopRequireDefault(_react); var _propTypes = require('prop-types'); var _propTypes2 = _interopRequireDefault(_propTypes); var _classnames = require('classnames'); var _classnames2 = _interopRequireDefault(_classnames); var _reactCssThemr = require('react-css-themr'); var _identifiers = require('../identifiers'); var _Button = require('../button/Button'); var _Button2 = _interopRequireDefault(_Button); var _Link = require('../link/Link'); var _Link2 = _interopRequireDefault(_Link); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var factory = function factory(Button, Link) { var Navigation = function Navigation(_ref) { var actions = _ref.actions, children = _ref.children, className = _ref.className, routes = _ref.routes, theme = _ref.theme, type = _ref.type; var _className = (0, _classnames2.default)(theme[type], className); var buttons = actions.map(function (action, index) { return _react2.default.createElement(Button, _extends({ className: theme.button, key: index }, action)) // eslint-disable-line ; }); var links = routes.map(function (route, index) { return _react2.default.createElement(Link, _extends({ className: theme.link, key: index }, route)) // eslint-disable-line ; }); return _react2.default.createElement( 'nav', { 'data-react-toolbox': 'navigation', className: _className }, links, buttons, children ); }; Navigation.propTypes = { actions: _propTypes2.default.array, // eslint-disable-line children: _propTypes2.default.node, className: _propTypes2.default.string, routes: _propTypes2.default.array, // eslint-disable-line theme: _propTypes2.default.shape({ button: _propTypes2.default.string, horizontal: _propTypes2.default.string, link: _propTypes2.default.string, vertical: _propTypes2.default.string }), type: _propTypes2.default.oneOf(['vertical', 'horizontal']) }; Navigation.defaultProps = { actions: [], className: '', type: 'horizontal', routes: [] }; return Navigation; }; var Navigation = factory(_Button2.default, _Link2.default); exports.default = (0, _reactCssThemr.themr)(_identifiers.NAVIGATION)(Navigation); exports.navigationFactory = factory; exports.Navigation = Navigation;