@panneau/layout
Version:
Layout core for Panneau
109 lines (86 loc) • 4.69 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _isObject = _interopRequireDefault(require("lodash/isObject"));
var _isArray = _interopRequireDefault(require("lodash/isArray"));
var _reactIntl = require("react-intl");
var _reactRouterDom = require("react-router-dom");
var _core = require("@panneau/core");
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
var propTypes = {
urlGenerator: _core.PropTypes.urlGenerator,
link: _propTypes["default"].string,
linkRoute: _propTypes["default"].string,
label: _core.PropTypes.label,
external: _propTypes["default"].bool,
isDropdown: _propTypes["default"].bool,
hasDropdown: _propTypes["default"].bool,
className: _propTypes["default"].string,
onClick: _propTypes["default"].func
};
var defaultProps = {
urlGenerator: null,
link: null,
linkRoute: null,
label: null,
external: false,
isDropdown: false,
hasDropdown: false,
className: null,
onClick: null
};
var NavbarLink = function NavbarLink(_ref) {
var urlGenerator = _ref.urlGenerator,
link = _ref.link,
linkRoute = _ref.linkRoute,
external = _ref.external,
label = _ref.label,
isDropdown = _ref.isDropdown,
hasDropdown = _ref.hasDropdown,
className = _ref.className,
onClick = _ref.onClick;
var inner = /*#__PURE__*/_react["default"].createElement(_react.Fragment, null, (0, _isObject["default"])(label) && typeof label.id !== 'undefined' ? /*#__PURE__*/_react["default"].createElement(_reactIntl.FormattedMessage, label || null) : label || '', hasDropdown ? ' ' : null, hasDropdown ? /*#__PURE__*/_react["default"].createElement("span", {
className: "caret"
}) : null);
var linkClassNames = (0, _classnames["default"])((0, _defineProperty2["default"])({
'nav-link': !isDropdown,
'dropdown-item': isDropdown,
'dropdown-toggle': hasDropdown
}, className, className !== null));
var dropdownProps = hasDropdown ? {
role: 'button',
'data-toggle': 'dropdown',
'aria-haspopup': 'true',
'aria-expanded': 'false'
} : null;
var finalLinkRoute = linkRoute !== null && urlGenerator ? urlGenerator.route.apply(urlGenerator, (0, _toConsumableArray2["default"])((0, _isArray["default"])(linkRoute) ? linkRoute : [linkRoute])) : null;
var finalLink = link || finalLinkRoute || '#';
return external ? /*#__PURE__*/_react["default"].createElement("a", (0, _extends2["default"])({
href: finalLink,
className: linkClassNames
}, dropdownProps, {
onClick: onClick
}), inner) : /*#__PURE__*/_react["default"].createElement(_reactRouterDom.Link, (0, _extends2["default"])({
to: {
pathname: finalLink
},
className: linkClassNames
}, dropdownProps, {
onClick: onClick
}), inner);
};
NavbarLink.propTypes = propTypes;
NavbarLink.defaultProps = defaultProps;
var _default = (0, _core.withUrlGenerator)()(NavbarLink);
exports["default"] = _default;