ultisuite-client/components/gmail/contacts-page/use-entering-item-keys.ts
R3D347HR4Y 07d57f13a8
Some checks are pending
E2E / Playwright e2e (push) Waiting to run
Add Contact Avatar Features and Improve UI Components
- Introduced new ContactAvatar and ContactAvatarPicker components for enhanced avatar management in contact views.
- Updated ContactDetailView and ContactFormView to utilize the new avatar components, improving user experience when adding or editing contacts.
- Enhanced ContactHoverCard and ContactRow components to display avatars, providing a more visually appealing interface.
- Added loading and error states in ContactsListView for better user feedback during data fetching.
- Implemented a new ContactsLoadState component to handle loading and error scenarios in the contacts list.
- Updated package.json to include @formkit/auto-animate for improved UI animations.
2026-06-06 20:26:51 +02:00

40 lines
1.2 KiB
TypeScript

"use client"
import { useEffect, useRef, useState, type ReactElement, type ReactNode } from "react"
function childKey(child: ReactNode, index: number): string {
if (child && typeof child === "object" && "key" in child) {
return String((child as ReactElement).key ?? index)
}
return String(index)
}
/** Clés des items ajoutés récemment (pour animation d'entrée unique). */
export function useEnteringItemKeys(items: ReactNode[]): Set<string> {
const seenKeysRef = useRef(new Set<string>())
const [enteringKeys, setEnteringKeys] = useState<Set<string>>(() => new Set())
const itemKeys = items.map(childKey).join("\0")
useEffect(() => {
const keys = items.map(childKey)
const keySet = new Set(keys)
const added = keys.filter((key) => !seenKeysRef.current.has(key))
for (const key of keys) {
seenKeysRef.current.add(key)
}
for (const key of [...seenKeysRef.current]) {
if (!keySet.has(key)) seenKeysRef.current.delete(key)
}
if (added.length === 0) return
setEnteringKeys(new Set(added))
const timer = window.setTimeout(() => setEnteringKeys(new Set()), 360)
return () => window.clearTimeout(timer)
}, [itemKeys, items])
return enteringKeys
}