UNPKG

@react-aria/menu

Version:
60 lines (53 loc) 2.53 kB
var $6CumN$reactariautils = require("@react-aria/utils"); var $6CumN$reactariaselection = require("@react-aria/selection"); function $parcel$export(e, n, v, s) { Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true}); } $parcel$export(module.exports, "menuData", () => $a3815f0132802737$export$6f49b4016bfc8d56); $parcel$export(module.exports, "useMenu", () => $a3815f0132802737$export$38eaa17faae8f579); /* * Copyright 2020 Adobe. All rights reserved. * This file is licensed to you under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. You may obtain a copy * of the License at http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS * OF ANY KIND, either express or implied. See the License for the specific language * governing permissions and limitations under the License. */ const $a3815f0132802737$export$6f49b4016bfc8d56 = new WeakMap(); function $a3815f0132802737$export$38eaa17faae8f579(props, state, ref) { let { shouldFocusWrap: shouldFocusWrap = true, onKeyDown: onKeyDown, onKeyUp: onKeyUp, ...otherProps } = props; if (!props['aria-label'] && !props['aria-labelledby']) console.warn('An aria-label or aria-labelledby prop is required for accessibility.'); let domProps = (0, $6CumN$reactariautils.filterDOMProps)(props, { labelable: true }); let { listProps: listProps } = (0, $6CumN$reactariaselection.useSelectableList)({ ...otherProps, ref: ref, selectionManager: state.selectionManager, collection: state.collection, disabledKeys: state.disabledKeys, shouldFocusWrap: shouldFocusWrap, linkBehavior: 'override' }); $a3815f0132802737$export$6f49b4016bfc8d56.set(state, { onClose: props.onClose, onAction: props.onAction }); return { menuProps: (0, $6CumN$reactariautils.mergeProps)(domProps, { onKeyDown: onKeyDown, onKeyUp: onKeyUp }, { role: 'menu', ...listProps, onKeyDown: (e)=>{ // don't clear the menu selected keys if the user is presses escape since escape closes the menu if (e.key !== 'Escape') listProps.onKeyDown(e); } }) }; } //# sourceMappingURL=useMenu.main.js.map