UNPKG

@orfeas126/box-ui-elements

Version:
59 lines (58 loc) 2.46 kB
const _excluded = ["activeClassName", "children", "className", "component", "exact", "isActive", "onClick", "replace", "strict", "to"]; function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var s = Object.getOwnPropertySymbols(e); for (r = 0; r < s.length; r++) o = s[r], t.includes(o) || {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; } function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.includes(n)) continue; t[n] = r[n]; } return t; } /** * * @file Nav Button component intended to mimic React Router's NavLink component for non-anchor elements * @author Box */ import * as React from 'react'; import classNames from 'classnames'; import { Route } from 'react-router-dom'; import PlainButton from '../../../components/plain-button'; import { isLeftClick } from '../../../utils/dom'; const NavButton = /*#__PURE__*/React.forwardRef((props, ref) => { const { activeClassName = 'bdl-is-active', children, className = 'bdl-NavButton', component: Component = PlainButton, exact, isActive, onClick, replace, strict, to } = props, rest = _objectWithoutProperties(props, _excluded); const path = typeof to === 'object' ? to.pathname : to; return /*#__PURE__*/React.createElement(Route, { exact: exact, path: path, strict: strict }, ({ history, location, match }) => { const isActiveValue = !!(isActive ? isActive(match, location) : match); return /*#__PURE__*/React.createElement(Component, _extends({ className: classNames(className, { [activeClassName]: isActiveValue }), onClick: event => { if (onClick) { onClick(event); } if (!event.defaultPrevented && isLeftClick(event)) { const method = replace ? history.replace : history.push; method(to); } }, ref: ref }, rest), children); }); }); export default NavButton; //# sourceMappingURL=NavButton.js.map