@lskjs/navbar
Version:
LSK ux subrepo: navbar
165 lines (131 loc) • 14.2 kB
JavaScript
"use strict";
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _classnames = _interopRequireDefault(require("classnames"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _all = _interopRequireDefault(require("prop-types-extra/lib/all"));
var _react = _interopRequireWildcard(require("react"));
var _uncontrollable = require("uncontrollable");
var _ThemeProvider = require("./ThemeProvider");
var _NavbarContext = _interopRequireDefault(require("./NavbarContext"));
var _CardContext = _interopRequireDefault(require("./CardContext"));
var _AbstractNav = _interopRequireDefault(require("./AbstractNav"));
var _NavItem = _interopRequireDefault(require("./NavItem"));
var _NavLink = _interopRequireDefault(require("./NavLink"));
var propTypes = {
/**
* @default 'nav'
*/
bsPrefix: _propTypes["default"].string,
/** @private */
navbarBsPrefix: _propTypes["default"].string,
/** @private */
cardHeaderBsPrefix: _propTypes["default"].string,
/**
* The visual variant of the nav items.
*
* @type {('tabs'|'pills')}
*/
variant: _propTypes["default"].string,
/**
* Marks the NavItem with a matching `eventKey` (or `href` if present) as active.
*
* @type {string}
*/
activeKey: _propTypes["default"].any,
/**
* Have all `NavItem`s proportionately fill all available width.
*/
fill: _propTypes["default"].bool,
/**
* Have all `NavItem`s evenly fill all available width.
*
* @type {boolean}
*/
justify: (0, _all["default"])(_propTypes["default"].bool, function (_ref) {
var justify = _ref.justify,
navbar = _ref.navbar;
return justify && navbar ? Error('justify navbar `Nav`s are not supported') : null;
}),
/**
* A callback fired when a NavItem is selected.
*
* ```js
* function (
* Any eventKey,
* SyntheticEvent event?
* )
* ```
*/
onSelect: _propTypes["default"].func,
/**
* ARIA role for the Nav, in the context of a TabContainer, the default will
* be set to "tablist", but can be overridden by the Nav when set explicitly.
*
* When the role is "tablist", NavLink focus is managed according to
* the ARIA authoring practices for tabs:
* https://www.w3.org/TR/2013/WD-wai-aria-practices-20130307/#tabpanel
*/
role: _propTypes["default"].string,
/**
* Apply styling an alignment for use in a Navbar. This prop will be set
* automatically when the Nav is used inside a Navbar.
*/
navbar: _propTypes["default"].bool,
as: _propTypes["default"].elementType,
/** @private */
onKeyDown: _propTypes["default"].func
};
var defaultProps = {
justify: false,
fill: false
};
var Nav = _react["default"].forwardRef(function (uncontrolledProps, ref) {
var _classNames;
var _useUncontrolled = (0, _uncontrollable.useUncontrolled)(uncontrolledProps, {
activeKey: 'onSelect'
}),
_useUncontrolled$as = _useUncontrolled.as,
as = _useUncontrolled$as === void 0 ? 'div' : _useUncontrolled$as,
bsPrefix = _useUncontrolled.bsPrefix,
variant = _useUncontrolled.variant,
fill = _useUncontrolled.fill,
justify = _useUncontrolled.justify,
navbar = _useUncontrolled.navbar,
className = _useUncontrolled.className,
children = _useUncontrolled.children,
activeKey = _useUncontrolled.activeKey,
props = (0, _objectWithoutProperties2["default"])(_useUncontrolled, ["as", "bsPrefix", "variant", "fill", "justify", "navbar", "className", "children", "activeKey"]);
bsPrefix = (0, _ThemeProvider.useBootstrapPrefix)(bsPrefix, 'nav');
var navbarBsPrefix, cardHeaderBsPrefix;
var navbarContext = (0, _react.useContext)(_NavbarContext["default"]);
var cardContext = (0, _react.useContext)(_CardContext["default"]);
if (navbarContext) {
navbarBsPrefix = navbarContext.bsPrefix;
navbar = navbar == null ? true : navbar;
} else if (cardContext) {
cardHeaderBsPrefix = cardContext.cardHeaderBsPrefix;
}
return /*#__PURE__*/_react["default"].createElement(_AbstractNav["default"], (0, _extends2["default"])({
as: as,
ref: ref,
activeKey: activeKey,
className: (0, _classnames["default"])(className, (_classNames = {}, (0, _defineProperty2["default"])(_classNames, bsPrefix, !navbar), (0, _defineProperty2["default"])(_classNames, "".concat(navbarBsPrefix, "-nav"), navbar), (0, _defineProperty2["default"])(_classNames, "".concat(cardHeaderBsPrefix, "-").concat(variant), !!cardHeaderBsPrefix), (0, _defineProperty2["default"])(_classNames, "".concat(bsPrefix, "-").concat(variant), !!variant), (0, _defineProperty2["default"])(_classNames, "".concat(bsPrefix, "-fill"), fill), (0, _defineProperty2["default"])(_classNames, "".concat(bsPrefix, "-justified"), justify), _classNames))
}, props), children);
});
Nav.displayName = 'Nav';
Nav.propTypes = propTypes;
Nav.defaultProps = defaultProps;
Nav.Item = _NavItem["default"];
Nav.Link = _NavLink["default"];
var _default = Nav;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/Nav.js"],"names":["propTypes","bsPrefix","PropTypes","string","navbarBsPrefix","cardHeaderBsPrefix","variant","activeKey","any","fill","bool","justify","navbar","Error","onSelect","func","role","as","elementType","onKeyDown","defaultProps","Nav","React","forwardRef","uncontrolledProps","ref","className","children","props","navbarContext","NavbarContext","cardContext","CardContext","displayName","Item","NavItem","Link","NavLink"],"mappings":"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","sourcesContent":["import classNames from 'classnames';\nimport PropTypes from 'prop-types';\n\nimport all from 'prop-types-extra/lib/all';\nimport React, { useContext } from 'react';\nimport { useUncontrolled } from 'uncontrollable';\n\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport NavbarContext from './NavbarContext';\nimport CardContext from './CardContext';\nimport AbstractNav from './AbstractNav';\nimport NavItem from './NavItem';\nimport NavLink from './NavLink';\n\nconst propTypes = {\n  /**\n   * @default 'nav'\n   */\n  bsPrefix: PropTypes.string,\n\n  /** @private */\n  navbarBsPrefix: PropTypes.string,\n  /** @private */\n  cardHeaderBsPrefix: PropTypes.string,\n\n  /**\n   * The visual variant of the nav items.\n   *\n   * @type {('tabs'|'pills')}\n   */\n  variant: PropTypes.string,\n\n  /**\n   * Marks the NavItem with a matching `eventKey` (or `href` if present) as active.\n   *\n   * @type {string}\n   */\n  activeKey: PropTypes.any,\n\n  /**\n   * Have all `NavItem`s proportionately fill all available width.\n   */\n  fill: PropTypes.bool,\n\n  /**\n   * Have all `NavItem`s evenly fill all available width.\n   *\n   * @type {boolean}\n   */\n  justify: all(PropTypes.bool, ({ justify, navbar }) =>\n    justify && navbar ? Error('justify navbar `Nav`s are not supported') : null,\n  ),\n\n  /**\n   * A callback fired when a NavItem is selected.\n   *\n   * ```js\n   * function (\n   *  Any eventKey,\n   *  SyntheticEvent event?\n   * )\n   * ```\n   */\n  onSelect: PropTypes.func,\n\n  /**\n   * ARIA role for the Nav, in the context of a TabContainer, the default will\n   * be set to \"tablist\", but can be overridden by the Nav when set explicitly.\n   *\n   * When the role is \"tablist\", NavLink focus is managed according to\n   * the ARIA authoring practices for tabs:\n   * https://www.w3.org/TR/2013/WD-wai-aria-practices-20130307/#tabpanel\n   */\n  role: PropTypes.string,\n\n  /**\n   * Apply styling an alignment for use in a Navbar. This prop will be set\n   * automatically when the Nav is used inside a Navbar.\n   */\n  navbar: PropTypes.bool,\n\n  as: PropTypes.elementType,\n\n  /** @private */\n  onKeyDown: PropTypes.func,\n};\n\nconst defaultProps = {\n  justify: false,\n  fill: false,\n};\n\nconst Nav = React.forwardRef((uncontrolledProps, ref) => {\n  let {\n    as = 'div',\n    bsPrefix,\n    variant,\n    fill,\n    justify,\n    navbar,\n    className,\n    children,\n    activeKey,\n    ...props\n  } = useUncontrolled(uncontrolledProps, { activeKey: 'onSelect' });\n\n  bsPrefix = useBootstrapPrefix(bsPrefix, 'nav');\n\n  let navbarBsPrefix, cardHeaderBsPrefix;\n\n  const navbarContext = useContext(NavbarContext);\n  const cardContext = useContext(CardContext);\n\n  if (navbarContext) {\n    navbarBsPrefix = navbarContext.bsPrefix;\n    navbar = navbar == null ? true : navbar;\n  } else if (cardContext) {\n    ({ cardHeaderBsPrefix } = cardContext);\n  }\n\n  return (\n    <AbstractNav\n      as={as}\n      ref={ref}\n      activeKey={activeKey}\n      className={classNames(className, {\n        [bsPrefix]: !navbar,\n        [`${navbarBsPrefix}-nav`]: navbar,\n        [`${cardHeaderBsPrefix}-${variant}`]: !!cardHeaderBsPrefix,\n        [`${bsPrefix}-${variant}`]: !!variant,\n        [`${bsPrefix}-fill`]: fill,\n        [`${bsPrefix}-justified`]: justify,\n      })}\n      {...props}\n    >\n      {children}\n    </AbstractNav>\n  );\n});\n\nNav.displayName = 'Nav';\nNav.propTypes = propTypes;\nNav.defaultProps = defaultProps;\n\nNav.Item = NavItem;\nNav.Link = NavLink;\n\nexport default Nav;\n"]}
//# sourceMappingURL=Nav.js.map