"use strict"; exports.__esModule = true; exports.default = void 0; exports.useDropdownMenu = useDropdownMenu; var _react = _interopRequireWildcard(require("react")); var React = _react; var _useCallbackRef = _interopRequireDefault(require("@restart/hooks/useCallbackRef")); var _DropdownContext = _interopRequireDefault(require("./DropdownContext")); var _usePopper = _interopRequireDefault(require("./usePopper")); var _useClickOutside = _interopRequireDefault(require("./useClickOutside")); var _mergeOptionsWithPopperConfig = _interopRequireDefault(require("./mergeOptionsWithPopperConfig")); var _jsxRuntime = require("react/jsx-runtime"); const _excluded = ["children", "usePopper"]; function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (e.indexOf(n) >= 0) continue; t[n] = r[n]; } return t; } const noop = () => {}; /** * @memberOf Dropdown * @param {object} options * @param {boolean} options.flip Automatically adjust the menu `drop` position based on viewport edge detection * @param {[number, number]} options.offset Define an offset distance between the Menu and the Toggle * @param {boolean} options.show Display the menu manually, ignored in the context of a `Dropdown` * @param {boolean} options.usePopper opt in/out of using PopperJS to position menus. When disabled you must position it yourself. * @param {string} options.rootCloseEvent The pointer event to listen for when determining "clicks outside" the menu for triggering a close. * @param {object} options.popperConfig Options passed to the [`usePopper`](/api/usePopper) hook. */ function useDropdownMenu(options = {}) { const context = (0, _react.useContext)(_DropdownContext.default); const [arrowElement, attachArrowRef] = (0, _useCallbackRef.default)(); const hasShownRef = (0, _react.useRef)(false); const { flip, offset, rootCloseEvent, fixed = false, placement: placementOverride, popperConfig = {}, enableEventListeners = true, usePopper: shouldUsePopper = !!context } = options; const show = (context == null ? void 0 : context.show) == null ? !!options.show : context.show; if (show && !hasShownRef.current) { hasShownRef.current = true; } const handleClose = e => { context == null ? void 0 : context.toggle(false, e); }; const { placement, setMenu, menuElement, toggleElement } = context || {}; const popper = (0, _usePopper.default)(toggleElement, menuElement, (0, _mergeOptionsWithPopperConfig.default)({ placement: placementOverride || placement || 'bottom-start', enabled: shouldUsePopper, enableEvents: enableEventListeners == null ? show : enableEventListeners, offset, flip, fixed, arrowElement, popperConfig })); const menuProps = Object.assign({ ref: setMenu || noop, 'aria-labelledby': toggleElement == null ? void 0 : toggleElement.id }, popper.attributes.popper, { style: popper.styles.popper }); const metadata = { show, placement, hasShown: hasShownRef.current, toggle: context == null ? void 0 : context.toggle, popper: shouldUsePopper ? popper : null, arrowProps: shouldUsePopper ? Object.assign({ ref: attachArrowRef }, popper.attributes.arrow, { style: popper.styles.arrow }) : {} }; (0, _useClickOutside.default)(menuElement, handleClose, { clickTrigger: rootCloseEvent, disabled: !show }); return [menuProps, metadata]; } /** * Also exported as `` from `Dropdown`. * * @displayName DropdownMenu * @memberOf Dropdown */ function DropdownMenu(_ref) { let { children, usePopper: usePopperProp = true } = _ref, options = _objectWithoutPropertiesLoose(_ref, _excluded); const [props, meta] = useDropdownMenu(Object.assign({}, options, { usePopper: usePopperProp })); return /*#__PURE__*/(0, _jsxRuntime.jsx)(_jsxRuntime.Fragment, { children: children(props, meta) }); } DropdownMenu.displayName = 'DropdownMenu'; /** @component */ var _default = exports.default = DropdownMenu;