LibreChat/client/src/hooks/useVirtualGrid.ts
Marco Beretta d82a63642d
🖼️ style: Improve Marketplace & Sharing Dialog UI
feat: Enhance CategoryTabs and Marketplace components for better responsiveness and navigation

feat: Refactor AgentCard and AgentGrid components for improved layout and accessibility

feat: Implement animated category transitions in AgentMarketplace and update NewChat component layout

feat: Refactor UI components for improved styling and accessibility in sharing dialogs

refactor: remove GenericManagePermissionsDialog and GrantAccessDialog components

- Deleted GenericManagePermissionsDialog and GrantAccessDialog components to streamline sharing functionality.
- Updated ManagePermissionsDialog to utilize AccessRolesPicker directly.
- Introduced UnifiedPeopleSearch for improved people selection experience.
- Enhanced PublicSharingToggle with InfoHoverCard for better user guidance.
- Adjusted AgentPanel to change error status to warning for duplicate agent versions.
- Updated translations to include new keys for search and access management.

feat: Add responsive design for SelectedPrincipalsList and improve layout in GenericGrantAccessDialog

feat: Enhance styling in SelectedPrincipalsList and SearchPicker components for improved UI consistency

feat: Improve PublicSharingToggle component with enhanced styling and accessibility features

feat: Introduce InfoHoverCard component and refactor enums for better organization

feat: Implement infinite scroll for agent grids and enhance performance

- Added `useInfiniteScroll` hook to manage infinite scrolling behavior in agent grids.
- Integrated infinite scroll functionality into `AgentGrid` and `VirtualizedAgentGrid` components.
- Updated `AgentMarketplace` to pass the scroll container to the agent grid components.
- Refactored loading indicators to show a spinner instead of a "Load More" button.
- Created `VirtualizedAgentGrid` component for optimized rendering of agent cards using virtualization.
- Added performance tests for `VirtualizedAgentGrid` to ensure efficient handling of large datasets.
- Updated translations to include new messages for end-of-results scenarios.

chore: Remove unused permission-related UI localization keys

ci: Update Agent model tests to handle duplicate support_contact updates

- Modified tests to ensure that updating an agent with the same support_contact does not create a new version and returns successfully.
- Enhanced verification for partial changes in support_contact, confirming no new version is created when content remains the same.

chore: Address ESLint, clean up unused imports and improve prop definitions in various components

ci: fix tests

ci: update tests

chore: remove unused search localization keys
2025-08-13 16:24:24 -04:00

66 lines
1.7 KiB
TypeScript

import { useCallback, useMemo } from 'react';
interface UseVirtualGridProps {
itemCount: number;
containerWidth: number;
itemHeight: number;
gapSize: number;
mobileColumnsCount: number;
desktopColumnsCount: number;
mobileBreakpoint: number;
}
interface UseVirtualGridReturn {
cardsPerRow: number;
rowCount: number;
rowHeight: number;
getRowItems: (rowIndex: number, items: any[]) => any[];
}
/**
* Custom hook for virtual grid calculations
* Handles responsive grid layout and item positioning for virtualized lists
*/
export const useVirtualGrid = ({
itemCount,
containerWidth,
itemHeight,
gapSize,
mobileColumnsCount,
desktopColumnsCount,
mobileBreakpoint = 768,
}: UseVirtualGridProps): UseVirtualGridReturn => {
// Calculate cards per row based on container width
const cardsPerRow = useMemo(() => {
return containerWidth >= mobileBreakpoint ? desktopColumnsCount : mobileColumnsCount;
}, [containerWidth, mobileBreakpoint, desktopColumnsCount, mobileColumnsCount]);
// Calculate total number of rows needed
const rowCount = useMemo(() => {
return Math.ceil(itemCount / cardsPerRow);
}, [itemCount, cardsPerRow]);
// Calculate row height including gap
const rowHeight = useMemo(() => {
return itemHeight + gapSize;
}, [itemHeight, gapSize]);
// Get items for a specific row
const getRowItems = useCallback(
(rowIndex: number, items: any[]) => {
const startIndex = rowIndex * cardsPerRow;
const endIndex = Math.min(startIndex + cardsPerRow, items.length);
return items.slice(startIndex, endIndex);
},
[cardsPerRow],
);
return {
cardsPerRow,
rowCount,
rowHeight,
getRowItems,
};
};
export default useVirtualGrid;