mirror of
https://github.com/snowball-tools/snowballtools-base.git
synced 2025-01-03 15:26:46 +00:00
🔧 chore: follow select changes
This commit is contained in:
parent
30c50a3eec
commit
f77f7c120a
@ -1,7 +1,6 @@
|
||||
import React, {
|
||||
useState,
|
||||
ComponentPropsWithoutRef,
|
||||
useCallback,
|
||||
useRef,
|
||||
useEffect,
|
||||
} from 'react';
|
||||
@ -34,7 +33,7 @@ export const UserSelect = ({ options, value }: UserSelectProps) => {
|
||||
const navigate = useNavigate();
|
||||
|
||||
const [selectedItem, setSelectedItem] = useState<UserSelectOption | null>(
|
||||
null,
|
||||
(value as UserSelectOption) || null,
|
||||
);
|
||||
const [dropdownOpen, setDropdownOpen] = useState(false);
|
||||
const [dropdownPosition, setDropdownPosition] = useState<'top' | 'bottom'>(
|
||||
@ -75,10 +74,8 @@ export const UserSelect = ({ options, value }: UserSelectProps) => {
|
||||
navigate(`/${selectedItem?.value}`);
|
||||
};
|
||||
|
||||
const isSelected = useCallback(
|
||||
(item: UserSelectOption) => selectedItem?.value === item.value,
|
||||
[selectedItem],
|
||||
);
|
||||
const isSelected = (item: UserSelectOption) =>
|
||||
selectedItem?.value === item.value;
|
||||
|
||||
const { isOpen, getMenuProps, highlightedIndex, getItemProps, openMenu } =
|
||||
useCombobox({
|
||||
@ -94,7 +91,7 @@ export const UserSelect = ({ options, value }: UserSelectProps) => {
|
||||
onIsOpenChange: ({ isOpen }) => {
|
||||
setDropdownOpen(isOpen ?? false);
|
||||
},
|
||||
selectedItem: selectedItem,
|
||||
selectedItem: value || null,
|
||||
itemToString: (item) => (item ? item.label : ''),
|
||||
});
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user