UNPKG

@dnb/eufemia

Version:

DNB Eufemia Design System UI Library

61 lines 1.85 kB
import React, { useCallback } from 'react'; import { getClosestScrollViewElement } from "../../../shared/component-helper.js"; import { useHeightAnimation } from "../../height-animation/useHeightAnimation.js"; import { TableAccordionContext } from "./TableAccordionContext.js"; export function useTableAnimationHandler({ innerRef, trRef, expanded, noAnimation }) { const tableAccordionContext = React.useContext(TableAccordionContext); const [ariaLive, setAriaLive] = React.useState(null); const open = Boolean(expanded || tableAccordionContext?.trIsOpen); const scrollViewHandler = useCallback(clip => { const scrollView = getClosestScrollViewElement(trRef.current); if (scrollView instanceof HTMLElement) { scrollView.style.overflowY = clip ? 'clip' : ''; } }, [trRef]); const onOpen = useCallback(state => { setAriaLive(state ? true : null); }, []); const onAnimationStart = useCallback(() => { scrollViewHandler(true); }, [scrollViewHandler]); const onAnimationEnd = useCallback(state => { const event = { target: trRef.current }; switch (state) { case 'opened': tableAccordionContext.onOpened?.(event); break; case 'closed': tableAccordionContext.onClosed?.(event); break; } scrollViewHandler(false); }, [scrollViewHandler, tableAccordionContext, trRef]); const { isInDOM, isAnimating, isVisibleParallax, firstPaintStyle } = useHeightAnimation(innerRef, { open, animate: Boolean(!noAnimation && !tableAccordionContext?.noAnimation), onOpen, onAnimationStart, onAnimationEnd }); return { ariaLive, isInDOM, isAnimating, isVisibleParallax, firstPaintStyle }; } export default useTableAnimationHandler; //# sourceMappingURL=useTableAnimationHandler.js.map