* feat: Skeleton loading #404 * fix: skeleton loading * fix: skeleton loading * feat: Skeleton loading #404 * fix: skeleton loading * fix: skeleton loading * Update CompanyPickerSkeleton.tsx * updated changes
83 lines
2.7 KiB
TypeScript
83 lines
2.7 KiB
TypeScript
import { useRef } from 'react';
|
|
import { useHotkeys } from 'react-hotkeys-hook';
|
|
|
|
import { EntityForSelect } from '@/relation-picker/types/EntityForSelect';
|
|
import { DropdownMenuItem } from '@/ui/components/menu/DropdownMenuItem';
|
|
import { DropdownMenuItemContainer } from '@/ui/components/menu/DropdownMenuItemContainer';
|
|
import { DropdownMenuSelectableItem } from '@/ui/components/menu/DropdownMenuSelectableItem';
|
|
import { Avatar } from '@/users/components/Avatar';
|
|
import { isDefined } from '@/utils/type-guards/isDefined';
|
|
|
|
import { useEntitySelectScroll } from '../hooks/useEntitySelectScroll';
|
|
|
|
import { CompanyPickerSkeleton } from './skeletons/CompanyPickerSkeleton';
|
|
import { DropdownMenuItemContainerSkeleton } from './skeletons/DropdownMenuItemContainerSkeleton';
|
|
|
|
export type EntitiesForSingleEntitySelect<
|
|
CustomEntityForSelect extends EntityForSelect,
|
|
> = {
|
|
selectedEntity: CustomEntityForSelect;
|
|
entitiesToSelect: CustomEntityForSelect[];
|
|
};
|
|
|
|
export function SingleEntitySelectBase<
|
|
CustomEntityForSelect extends EntityForSelect,
|
|
>({
|
|
entities,
|
|
onEntitySelected,
|
|
}: {
|
|
entities: EntitiesForSingleEntitySelect<CustomEntityForSelect>;
|
|
onEntitySelected: (entity: CustomEntityForSelect) => void;
|
|
}) {
|
|
const containerRef = useRef<HTMLDivElement>(null);
|
|
const entitiesInDropdown = isDefined(entities.selectedEntity)
|
|
? [entities.selectedEntity, ...(entities.entitiesToSelect ?? [])]
|
|
: entities.entitiesToSelect ?? [];
|
|
|
|
const { hoveredIndex } = useEntitySelectScroll({
|
|
entities: entitiesInDropdown,
|
|
containerRef,
|
|
});
|
|
|
|
useHotkeys(
|
|
'enter',
|
|
() => {
|
|
onEntitySelected(entitiesInDropdown[hoveredIndex]);
|
|
},
|
|
{
|
|
enableOnContentEditable: true,
|
|
enableOnFormTags: true,
|
|
},
|
|
[entitiesInDropdown, hoveredIndex, onEntitySelected],
|
|
);
|
|
|
|
return (
|
|
<DropdownMenuItemContainer ref={containerRef}>
|
|
{entities.loading ? (
|
|
<DropdownMenuItemContainerSkeleton>
|
|
<CompanyPickerSkeleton count={10} />
|
|
</DropdownMenuItemContainerSkeleton>
|
|
) : entitiesInDropdown.length === 0 ? (
|
|
<DropdownMenuItem>No result</DropdownMenuItem>
|
|
) : (
|
|
entitiesInDropdown?.map((entity, index) => (
|
|
<DropdownMenuSelectableItem
|
|
key={entity.id}
|
|
selected={entities.selectedEntity?.id === entity.id}
|
|
hovered={hoveredIndex === index}
|
|
onClick={() => onEntitySelected(entity)}
|
|
>
|
|
<Avatar
|
|
avatarUrl={entity.avatarUrl}
|
|
placeholder={entity.name}
|
|
size={16}
|
|
type={entity.avatarType ?? 'rounded'}
|
|
/>
|
|
{entity.name}
|
|
</DropdownMenuSelectableItem>
|
|
))
|
|
)}
|
|
</DropdownMenuItemContainer>
|
|
);
|
|
}
|