UNPKG

@lskjs/navbar

Version:

LSK ux subrepo: navbar

141 lines (110 loc) 14.5 kB
"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 _react = _interopRequireWildcard(require("react")); var _DropdownMenu = require("react-overlays/DropdownMenu"); var _useMergedRefs = _interopRequireDefault(require("@restart/hooks/useMergedRefs")); var _NavbarContext = _interopRequireDefault(require("./NavbarContext")); var _ThemeProvider = require("./ThemeProvider"); var _useWrappedRefWithWarning = _interopRequireDefault(require("./useWrappedRefWithWarning")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var propTypes = { /** * @default 'dropdown-menu' */ bsPrefix: _propTypes["default"].string, /** Controls the visibility of the Dropdown menu */ show: _propTypes["default"].bool, /** Have the dropdown switch to it's opposite placement when necessary to stay on screen. */ flip: _propTypes["default"].bool, /** Aligns the Dropdown menu to the right of it's container. */ alignRight: _propTypes["default"].bool, onSelect: _propTypes["default"].func, /** * Which event when fired outside the component will cause it to be closed * * *Note: For custom dropdown components, you will have to pass the * `rootCloseEvent` to `<RootCloseWrapper>` in your custom dropdown menu * component ([similarly to how it is implemented in `<Dropdown.Menu>`](https://github.com/react-bootstrap/react-bootstrap/blob/v0.31.5/src/DropdownMenu.js#L115-L119)).* */ rootCloseEvent: _propTypes["default"].oneOf(['click', 'mousedown']), /** * Control the rendering of the DropdownMenu. All non-menu props * (listed here) are passed through to the `as` Component. * * If providing a custom, non DOM, component. the `show`, `close` and `alignRight` props * are also injected and should be handled appropriately. */ as: _propTypes["default"].elementType, /** * A set of popper options and props passed directly to react-popper's Popper component. */ popperConfig: _propTypes["default"].object }; var defaultProps = { alignRight: false, flip: true }; var DropdownMenu = _react["default"].forwardRef(function (_ref, ref) { var bsPrefix = _ref.bsPrefix, className = _ref.className, alignRight = _ref.alignRight, rootCloseEvent = _ref.rootCloseEvent, flip = _ref.flip, popperConfig = _ref.popperConfig, showProps = _ref.show, _ref$as = _ref.as, Component = _ref$as === void 0 ? 'div' : _ref$as, props = (0, _objectWithoutProperties2["default"])(_ref, ["bsPrefix", "className", "alignRight", "rootCloseEvent", "flip", "popperConfig", "show", "as"]); var isNavbar = (0, _react.useContext)(_NavbarContext["default"]); var prefix = (0, _ThemeProvider.useBootstrapPrefix)(bsPrefix, 'dropdown-menu'); var _useDropdownMenu = (0, _DropdownMenu.useDropdownMenu)({ flip: flip, popperConfig: popperConfig, rootCloseEvent: rootCloseEvent, show: showProps, alignEnd: alignRight, usePopper: !isNavbar }), hasShown = _useDropdownMenu.hasShown, placement = _useDropdownMenu.placement, show = _useDropdownMenu.show, alignEnd = _useDropdownMenu.alignEnd, close = _useDropdownMenu.close, menuProps = _useDropdownMenu.props; menuProps.ref = (0, _useMergedRefs["default"])(menuProps.ref, (0, _useWrappedRefWithWarning["default"])(ref, 'DropdownMenu')); if (!hasShown) return null; // For custom components provide additional, non-DOM, props; if (typeof Component !== 'string') { menuProps.show = show; menuProps.close = close; menuProps.alignRight = alignEnd; } var style = props.style; if (placement) { // we don't need the default popper style, // menus are display: none when not shown. style = _objectSpread(_objectSpread({}, style), menuProps.style); props['x-placement'] = placement; } return /*#__PURE__*/_react["default"].createElement(Component, (0, _extends2["default"])({}, props, menuProps, { style: style, className: (0, _classnames["default"])(className, prefix, show && 'show', alignEnd && "".concat(prefix, "-right")) })); }); DropdownMenu.displayName = 'DropdownMenu'; DropdownMenu.propTypes = propTypes; DropdownMenu.defaultProps = defaultProps; var _default = DropdownMenu; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/DropdownMenu.js"],"names":["propTypes","bsPrefix","PropTypes","string","show","bool","flip","alignRight","onSelect","func","rootCloseEvent","oneOf","as","elementType","popperConfig","object","defaultProps","DropdownMenu","React","forwardRef","ref","className","showProps","Component","props","isNavbar","NavbarContext","prefix","alignEnd","usePopper","hasShown","placement","close","menuProps","style","displayName"],"mappings":"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","sourcesContent":["import classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { useContext } from 'react';\nimport { useDropdownMenu } from 'react-overlays/DropdownMenu';\nimport useMergedRefs from '@restart/hooks/useMergedRefs';\nimport NavbarContext from './NavbarContext';\nimport { useBootstrapPrefix } from './ThemeProvider';\nimport useWrappedRefWithWarning from './useWrappedRefWithWarning';\n\nconst propTypes = {\n  /**\n   * @default 'dropdown-menu'\n   */\n  bsPrefix: PropTypes.string,\n\n  /** Controls the visibility of the Dropdown menu  */\n  show: PropTypes.bool,\n\n  /** Have the dropdown switch to it's opposite placement when necessary to stay on screen. */\n  flip: PropTypes.bool,\n\n  /** Aligns the Dropdown menu to the right of it's container. */\n  alignRight: PropTypes.bool,\n\n  onSelect: PropTypes.func,\n\n  /**\n   * Which event when fired outside the component will cause it to be closed\n   *\n   * *Note: For custom dropdown components, you will have to pass the\n   * `rootCloseEvent` to `<RootCloseWrapper>` in your custom dropdown menu\n   * component ([similarly to how it is implemented in `<Dropdown.Menu>`](https://github.com/react-bootstrap/react-bootstrap/blob/v0.31.5/src/DropdownMenu.js#L115-L119)).*\n   */\n  rootCloseEvent: PropTypes.oneOf(['click', 'mousedown']),\n\n  /**\n   * Control the rendering of the DropdownMenu. All non-menu props\n   * (listed here) are passed through to the `as` Component.\n   *\n   * If providing a custom, non DOM, component. the `show`, `close` and `alignRight` props\n   * are also injected and should be handled appropriately.\n   */\n  as: PropTypes.elementType,\n\n  /**\n   * A set of popper options and props passed directly to react-popper's Popper component.\n   */\n  popperConfig: PropTypes.object,\n};\n\nconst defaultProps = {\n  alignRight: false,\n  flip: true,\n};\n\nconst DropdownMenu = React.forwardRef(\n  (\n    {\n      bsPrefix,\n      className,\n      alignRight,\n      rootCloseEvent,\n      flip,\n      popperConfig,\n      show: showProps,\n      // Need to define the default \"as\" during prop destructuring to be compatible with styled-components github.com/react-bootstrap/react-bootstrap/issues/3595\n      as: Component = 'div',\n      ...props\n    },\n    ref,\n  ) => {\n    const isNavbar = useContext(NavbarContext);\n    const prefix = useBootstrapPrefix(bsPrefix, 'dropdown-menu');\n    const {\n      hasShown,\n      placement,\n      show,\n      alignEnd,\n      close,\n      props: menuProps,\n    } = useDropdownMenu({\n      flip,\n      popperConfig,\n      rootCloseEvent,\n      show: showProps,\n      alignEnd: alignRight,\n      usePopper: !isNavbar,\n    });\n\n    menuProps.ref = useMergedRefs(\n      menuProps.ref,\n      useWrappedRefWithWarning(ref, 'DropdownMenu'),\n    );\n\n    if (!hasShown) return null;\n\n    // For custom components provide additional, non-DOM, props;\n    if (typeof Component !== 'string') {\n      menuProps.show = show;\n      menuProps.close = close;\n      menuProps.alignRight = alignEnd;\n    }\n    let style = props.style;\n    if (placement) {\n      // we don't need the default popper style,\n      // menus are display: none when not shown.\n      style = { ...style, ...menuProps.style };\n      props['x-placement'] = placement;\n    }\n    return (\n      <Component\n        {...props}\n        {...menuProps}\n        style={style}\n        className={classNames(\n          className,\n          prefix,\n          show && 'show',\n          alignEnd && `${prefix}-right`,\n        )}\n      />\n    );\n  },\n);\n\nDropdownMenu.displayName = 'DropdownMenu';\nDropdownMenu.propTypes = propTypes;\nDropdownMenu.defaultProps = defaultProps;\n\nexport default DropdownMenu;\n"]} //# sourceMappingURL=DropdownMenu.js.map