forked from cerc-io/snowballtools-base
🐛 fix: onChange not triggered. thanks @ayungavis
This commit is contained in:
parent
a5b4103515
commit
fe427a9fb8
@ -5,14 +5,14 @@ import React, {
|
|||||||
useEffect,
|
useEffect,
|
||||||
} from 'react';
|
} from 'react';
|
||||||
import { useNavigate } from 'react-router-dom';
|
import { useNavigate } from 'react-router-dom';
|
||||||
import { useCombobox } from 'downshift';
|
import { useSelect } from 'downshift';
|
||||||
import { UserSelectTheme, userSelectTheme } from './UserSelect.theme';
|
|
||||||
import {
|
import {
|
||||||
BuildingIcon,
|
BuildingIcon,
|
||||||
ChevronUpDown,
|
ChevronUpDown,
|
||||||
SettingsSlidersIcon,
|
SettingsSlidersIcon,
|
||||||
} from 'components/shared/CustomIcon';
|
} from 'components/shared/CustomIcon';
|
||||||
import { cn } from 'utils/classnames';
|
import { cn } from 'utils/classnames';
|
||||||
|
import { UserSelectTheme, userSelectTheme } from './UserSelect.theme';
|
||||||
import { EmptyUserSelectItem, UserSelectItem } from './UserSelectItem';
|
import { EmptyUserSelectItem, UserSelectItem } from './UserSelectItem';
|
||||||
|
|
||||||
export type UserSelectOption = {
|
export type UserSelectOption = {
|
||||||
@ -77,21 +77,25 @@ export const UserSelect = ({ options, value }: UserSelectProps) => {
|
|||||||
const isSelected = (item: UserSelectOption) =>
|
const isSelected = (item: UserSelectOption) =>
|
||||||
selectedItem?.value === item.value;
|
selectedItem?.value === item.value;
|
||||||
|
|
||||||
const { isOpen, getMenuProps, highlightedIndex, getItemProps, openMenu } =
|
const {
|
||||||
useCombobox({
|
isOpen,
|
||||||
|
getMenuProps,
|
||||||
|
getToggleButtonProps,
|
||||||
|
highlightedIndex,
|
||||||
|
getItemProps,
|
||||||
|
openMenu,
|
||||||
|
} = useSelect({
|
||||||
items: options,
|
items: options,
|
||||||
// @ts-expect-error – there are two params but we don't need the second one
|
// @ts-expect-error – there are two params but we don't need the second one
|
||||||
isItemDisabled: (item) => item.disabled,
|
isItemDisabled: (item) => item.disabled,
|
||||||
onSelectedItemChange: ({ selectedItem }) => {
|
onSelectedItemChange: ({ selectedItem }) => {
|
||||||
if (selectedItem) {
|
if (selectedItem) {
|
||||||
console.log(selectedItem);
|
|
||||||
handleSelectedItemChange(selectedItem);
|
handleSelectedItemChange(selectedItem);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
onIsOpenChange: ({ isOpen }) => {
|
onIsOpenChange: ({ isOpen }) => {
|
||||||
setDropdownOpen(isOpen ?? false);
|
setDropdownOpen(isOpen ?? false);
|
||||||
},
|
},
|
||||||
selectedItem: value || null,
|
|
||||||
itemToString: (item) => (item ? item.label : ''),
|
itemToString: (item) => (item ? item.label : ''),
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -103,13 +107,17 @@ export const UserSelect = ({ options, value }: UserSelectProps) => {
|
|||||||
<div className={theme.container()}>
|
<div className={theme.container()}>
|
||||||
{/* Input */}
|
{/* Input */}
|
||||||
<div
|
<div
|
||||||
|
{...getToggleButtonProps({
|
||||||
|
ref: inputWrapperRef,
|
||||||
|
suppressRefError: true,
|
||||||
|
})}
|
||||||
ref={inputWrapperRef}
|
ref={inputWrapperRef}
|
||||||
onClick={() => !dropdownOpen && openMenu()}
|
onClick={() => !dropdownOpen && openMenu()}
|
||||||
className="cursor-pointer relative py-2 pl-2 pr-4 flex min-w-[200px] w-full items-center justify-between rounded-xl bg-surface-card shadow-sm"
|
className="cursor-pointer relative py-2 pl-2 pr-4 flex min-w-[200px] w-full items-center justify-between rounded-xl bg-surface-card shadow-sm"
|
||||||
>
|
>
|
||||||
<div className="flex gap-3 w-full mr-2">
|
<div className="flex gap-3 w-full mr-2">
|
||||||
<img
|
<img
|
||||||
src="/logo.svg"
|
src={selectedItem?.imgSrc || '/logo.svg'}
|
||||||
alt="Snowball Logo"
|
alt="Snowball Logo"
|
||||||
className="h-10 w-10 rounded-lg"
|
className="h-10 w-10 rounded-lg"
|
||||||
/>
|
/>
|
||||||
|
Loading…
Reference in New Issue
Block a user