@react-aria/menu
Version:
Spectrum UI components in React
60 lines (53 loc) • 2.53 kB
JavaScript
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