* Chore(front): Create Storybook tests for the DropdownMenu component Co-authored-by: Benjamin Mayanja V <vibenjamin6@gmail.com> Co-authored-by: FellipeMTX <fellipefacdir@gmail.com> * Fix the tests Co-authored-by: Benjamin Mayanja V <vibenjamin6@gmail.com> Co-authored-by: FellipeMTX <fellipefacdir@gmail.com> * Simplify Dropdown * Remove console.log --------- Co-authored-by: Benjamin Mayanja V <vibenjamin6@gmail.com> Co-authored-by: FellipeMTX <fellipefacdir@gmail.com> Co-authored-by: Charles Bochet <charles@twenty.com>
92 lines
2.3 KiB
TypeScript
92 lines
2.3 KiB
TypeScript
import { useRef } from 'react';
|
|
|
|
import { DropdownMenu } from '@/ui/layout/dropdown/components/DropdownMenu';
|
|
import { DropdownMenuSearchInput } from '@/ui/layout/dropdown/components/DropdownMenuSearchInput';
|
|
import { DropdownMenuSeparator } from '@/ui/layout/dropdown/components/DropdownMenuSeparator';
|
|
import { useListenClickOutside } from '@/ui/utilities/pointer-event/hooks/useListenClickOutside';
|
|
import { isDefined } from '~/utils/isDefined';
|
|
|
|
import { useEntitySelectSearch } from '../hooks/useEntitySelectSearch';
|
|
import { EntityForSelect } from '../types/EntityForSelect';
|
|
|
|
import {
|
|
SingleEntitySelectBase,
|
|
SingleEntitySelectBaseProps,
|
|
} from './SingleEntitySelectBase';
|
|
|
|
export type SingleEntitySelectProps<
|
|
CustomEntityForSelect extends EntityForSelect,
|
|
> = {
|
|
disableBackgroundBlur?: boolean;
|
|
onCreate?: () => void;
|
|
width?: number;
|
|
} & Pick<
|
|
SingleEntitySelectBaseProps<CustomEntityForSelect>,
|
|
| 'EmptyIcon'
|
|
| 'emptyLabel'
|
|
| 'entitiesToSelect'
|
|
| 'loading'
|
|
| 'onCancel'
|
|
| 'onEntitySelected'
|
|
| 'selectedEntity'
|
|
>;
|
|
|
|
export const SingleEntitySelect = <
|
|
CustomEntityForSelect extends EntityForSelect,
|
|
>({
|
|
EmptyIcon,
|
|
disableBackgroundBlur = false,
|
|
emptyLabel,
|
|
entitiesToSelect,
|
|
loading,
|
|
onCancel,
|
|
onCreate,
|
|
onEntitySelected,
|
|
selectedEntity,
|
|
width = 200,
|
|
}: SingleEntitySelectProps<CustomEntityForSelect>) => {
|
|
const containerRef = useRef<HTMLDivElement>(null);
|
|
|
|
const { searchFilter, handleSearchFilterChange } = useEntitySelectSearch();
|
|
|
|
const showCreateButton = isDefined(onCreate) && searchFilter !== '';
|
|
|
|
useListenClickOutside({
|
|
refs: [containerRef],
|
|
callback: (event) => {
|
|
event.stopImmediatePropagation();
|
|
|
|
onCancel?.();
|
|
},
|
|
});
|
|
|
|
return (
|
|
<DropdownMenu
|
|
disableBlur={disableBackgroundBlur}
|
|
ref={containerRef}
|
|
width={width}
|
|
data-select-disable
|
|
>
|
|
<DropdownMenuSearchInput
|
|
value={searchFilter}
|
|
onChange={handleSearchFilterChange}
|
|
autoFocus
|
|
/>
|
|
<DropdownMenuSeparator />
|
|
<SingleEntitySelectBase
|
|
{...{
|
|
EmptyIcon,
|
|
emptyLabel,
|
|
entitiesToSelect,
|
|
loading,
|
|
onCancel,
|
|
onCreate,
|
|
onEntitySelected,
|
|
selectedEntity,
|
|
showCreateButton,
|
|
}}
|
|
/>
|
|
</DropdownMenu>
|
|
);
|
|
};
|