forked from adobe/react-spectrum
-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathuseSelectableList.ts
More file actions
92 lines (85 loc) · 3.06 KB
/
useSelectableList.ts
File metadata and controls
92 lines (85 loc) · 3.06 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
* 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.
*/
import {AriaSelectableCollectionOptions, useSelectableCollection} from './useSelectableCollection';
import {Collection, DOMAttributes, Key, KeyboardDelegate, LayoutDelegate, Node, Orientation} from '@react-types/shared';
import {ListKeyboardDelegate} from './ListKeyboardDelegate';
import {useCollator} from '@react-aria/i18n';
import {useMemo} from 'react';
export interface AriaSelectableListOptions extends Omit<AriaSelectableCollectionOptions, 'keyboardDelegate'> {
/**
* State of the collection.
*/
collection: Collection<Node<unknown>>,
/**
* A delegate object that implements behavior for keyboard focus movement.
*/
keyboardDelegate?: KeyboardDelegate,
/**
* A delegate object that provides layout information for items in the collection.
* By default this uses the DOM, but this can be overridden to implement things like
* virtualized scrolling.
*/
layoutDelegate?: LayoutDelegate,
/**
* The item keys that are disabled. These items cannot be selected, focused, or otherwise interacted with.
*/
disabledKeys: Set<Key>,
/**
* The primary orientation of the items. Usually this is the direction that the collection scrolls.
* @default 'vertical'
*/
orientation?: Orientation
}
export interface SelectableListAria {
/**
* Props for the option element.
*/
listProps: DOMAttributes
}
/**
* Handles interactions with a selectable list.
*/
export function useSelectableList(props: AriaSelectableListOptions): SelectableListAria {
let {
selectionManager,
collection,
disabledKeys,
ref,
keyboardDelegate,
layoutDelegate,
orientation
} = props;
// By default, a KeyboardDelegate is provided which uses the DOM to query layout information (e.g. for page up/page down).
// When virtualized, the layout object will be passed in as a prop and override this.
let collator = useCollator({usage: 'search', sensitivity: 'base'});
let disabledBehavior = selectionManager.disabledBehavior;
let delegate = useMemo(() => (
keyboardDelegate || new ListKeyboardDelegate({
collection,
disabledKeys,
disabledBehavior,
ref,
collator,
layoutDelegate,
orientation
})
), [keyboardDelegate, layoutDelegate, collection, disabledKeys, ref, collator, disabledBehavior, orientation]);
let {collectionProps} = useSelectableCollection({
...props,
ref,
selectionManager,
keyboardDelegate: delegate
});
return {
listProps: collectionProps
};
}