import { useParams } from 'react-router-dom'; import { useFilteredObjectMetadataItemsForWorkspaceFavorites } from '@/navigation/hooks/useObjectMetadataItemsInWorkspaceFavorites'; import { NavigationDrawerSectionForObjectMetadataItems } from '@/object-metadata/components/NavigationDrawerSectionForObjectMetadataItems'; import { NavigationDrawerSectionForObjectMetadataItemsSkeletonLoader } from '@/object-metadata/components/NavigationDrawerSectionForObjectMetadataItemsSkeletonLoader'; import { useFilteredObjectMetadataItems } from '@/object-metadata/hooks/useFilteredObjectMetadataItems'; import { useIsPrefetchLoading } from '@/prefetch/hooks/useIsPrefetchLoading'; export const NavigationDrawerOpenedSection = () => { const { activeObjectMetadataItems } = useFilteredObjectMetadataItems(); const filteredActiveObjectMetadataItems = activeObjectMetadataItems.filter( (item) => !item.isRemote, ); const loading = useIsPrefetchLoading(); const { activeObjectMetadataItems: workspaceFavoritesObjectMetadataItems } = useFilteredObjectMetadataItemsForWorkspaceFavorites(); const { objectNamePlural: currentObjectNamePlural, objectNameSingular: currentObjectNameSingular, } = useParams(); if (!currentObjectNamePlural && !currentObjectNameSingular) { return; } const objectMetadataItem = filteredActiveObjectMetadataItems.find( (item) => item.namePlural === currentObjectNamePlural || item.nameSingular === currentObjectNameSingular, ); if (!objectMetadataItem) { return; } const shouldDisplayObjectInOpenedSection = !workspaceFavoritesObjectMetadataItems .map((item) => item.id) .includes(objectMetadataItem.id); if (loading) { return ; } return ( shouldDisplayObjectInOpenedSection && ( ) ); };