From f1126f68087499b02e442d603ea06c7a0409abc6 Mon Sep 17 00:00:00 2001 From: SukkaW Date: Sun, 21 Jan 2024 18:18:09 +0800 Subject: [PATCH] perf: enable memoization --- src/use-next-link-props/index.ts | 36 +++++++++++++++----------------- 1 file changed, 17 insertions(+), 19 deletions(-) diff --git a/src/use-next-link-props/index.ts b/src/use-next-link-props/index.ts index a41cdee6..20c291fe 100644 --- a/src/use-next-link-props/index.ts +++ b/src/use-next-link-props/index.ts @@ -139,21 +139,19 @@ export const useNextLink = ( ); }, [appPrefetchKind, isVisible, prefetchEnabled, resolvedHref, router]); - const callbackRef: React.RefCallback = useCallback((el: HTMLAnchorElement | null) => { - // track the element visibility - setIntersectionRef(el); - - if (typeof ref === 'function') { - ref(el); - } else if (ref && el) { - // We are acting on React behalf to assign the passed-in ref - (ref as React.MutableRefObject).current = el; - } - }, [ref, setIntersectionRef]); - const childProps: UseNextLinkReturnProps = { - ref: callbackRef, - onClick(e) { + ref: useCallback>((el: HTMLAnchorElement | null) => { + // track the element visibility + setIntersectionRef(el); + + if (typeof ref === 'function') { + ref(el); + } else if (ref && el) { + // We are acting on React behalf to assign the passed-in ref + (ref as React.MutableRefObject).current = el; + } + }, [ref, setIntersectionRef]), + onClick: useCallback((e) => { if (typeof onClick === 'function') { onClick(e); } @@ -177,8 +175,8 @@ export const useNextLink = ( startTransition(() => { router[replace ? 'replace' : 'push'](resolvedHref, { scroll: routerScroll }); }); - }, - onMouseEnter(e) { + }, [onClick, replace, resolvedHref, router, routerScroll]), + onMouseEnter: useCallback((e) => { if (typeof onMouseEnter === 'function') { onMouseEnter(e); } @@ -198,8 +196,8 @@ export const useNextLink = ( kind: appPrefetchKind as PrefetchKind } ); - }, - onTouchStart(e) { + }, [appPrefetchKind, onMouseEnter, prefetchEnabled, resolvedHref, router]), + onTouchStart: useCallback((e) => { if (typeof onTouchStart === 'function') { onTouchStart(e); } @@ -219,7 +217,7 @@ export const useNextLink = ( kind: appPrefetchKind as PrefetchKind } ); - }, + }, [appPrefetchKind, onTouchStart, prefetchEnabled, resolvedHref, router]), ...restProps };