react-aria
Version:
Spectrum UI components in React
85 lines (74 loc) • 4.31 kB
JavaScript
import {filterDOMProps as $8e9d2fae0ecb9001$export$457c3d6518dd4c6f} from "../utils/filterDOMProps.mjs";
import {listMap as $c1c90317e8bffe4d$export$5b9bb410392e3991} from "./utils.mjs";
import {mergeProps as $bbaa08b3cd72f041$export$9d1611c77c2fe928} from "../utils/mergeProps.mjs";
import {useGridSelectionAnnouncement as $2b2556a8276954c1$export$137e594ef3218a10} from "../grid/useGridSelectionAnnouncement.mjs";
import {useHasTabbableChild as $bf14c9739fda2eb3$export$eac1895992b9f3d6} from "../focus/useHasTabbableChild.mjs";
import {useHighlightSelectionDescription as $40ae3c60ef0e2e61$export$be42ebdab07ae4c2} from "../grid/useHighlightSelectionDescription.mjs";
import {useId as $390e54f620492c70$export$f680877a34711e37} from "../utils/useId.mjs";
import {useSelectableList as $64903b4b31b6bb2a$export$b95089534ab7c1fd} from "../selection/useSelectableList.mjs";
/*
* Copyright 2022 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.
*/
function $34d813d3524a584a$export$664f9155035607eb(props, state, ref) {
let { isVirtualized: isVirtualized, keyboardDelegate: keyboardDelegate, layoutDelegate: layoutDelegate, onAction: onAction, disallowTypeAhead: disallowTypeAhead, linkBehavior: linkBehavior = 'action', keyboardNavigationBehavior: keyboardNavigationBehavior = 'arrow', escapeKeyBehavior: escapeKeyBehavior = 'clearSelection', shouldSelectOnPressUp: shouldSelectOnPressUp } = props;
if (!props['aria-label'] && !props['aria-labelledby']) console.warn('An aria-label or aria-labelledby prop is required for accessibility.');
let { listProps: listProps } = (0, $64903b4b31b6bb2a$export$b95089534ab7c1fd)({
selectionManager: state.selectionManager,
collection: state.collection,
disabledKeys: state.disabledKeys,
ref: ref,
keyboardDelegate: keyboardDelegate,
layoutDelegate: layoutDelegate,
isVirtualized: isVirtualized,
selectOnFocus: state.selectionManager.selectionBehavior === 'replace',
shouldFocusWrap: props.shouldFocusWrap,
linkBehavior: linkBehavior,
disallowTypeAhead: disallowTypeAhead,
autoFocus: props.autoFocus,
escapeKeyBehavior: escapeKeyBehavior
});
let id = (0, $390e54f620492c70$export$f680877a34711e37)(props.id);
(0, $c1c90317e8bffe4d$export$5b9bb410392e3991).set(state, {
id: id,
onAction: onAction,
linkBehavior: linkBehavior,
keyboardNavigationBehavior: keyboardNavigationBehavior,
shouldSelectOnPressUp: shouldSelectOnPressUp
});
let descriptionProps = (0, $40ae3c60ef0e2e61$export$be42ebdab07ae4c2)({
selectionManager: state.selectionManager,
hasItemActions: !!onAction
});
let hasTabbableChild = (0, $bf14c9739fda2eb3$export$eac1895992b9f3d6)(ref, {
isDisabled: state.collection.size !== 0
});
let domProps = (0, $8e9d2fae0ecb9001$export$457c3d6518dd4c6f)(props, {
labelable: true
});
let gridProps = (0, $bbaa08b3cd72f041$export$9d1611c77c2fe928)(domProps, {
role: 'grid',
id: id,
'aria-multiselectable': state.selectionManager.selectionMode === 'multiple' ? 'true' : undefined
}, // If collection is empty, make sure the grid is tabbable unless there is a child tabbable element.
state.collection.size === 0 ? {
tabIndex: hasTabbableChild ? -1 : 0
} : listProps, descriptionProps);
if (isVirtualized) {
gridProps['aria-rowcount'] = state.collection.size;
gridProps['aria-colcount'] = 1;
}
(0, $2b2556a8276954c1$export$137e594ef3218a10)({}, state);
return {
gridProps: gridProps
};
}
export {$34d813d3524a584a$export$664f9155035607eb as useGridList};
//# sourceMappingURL=useGridList.mjs.map