24 lines
437 B
TypeScript
24 lines
437 B
TypeScript
|
|
'use client';
|
||
|
|
|
||
|
|
import { useCallback, useEffect } from 'react';
|
||
|
|
|
||
|
|
import { useRouter } from 'next/navigation';
|
||
|
|
|
||
|
|
export const RefreshOnFocus = () => {
|
||
|
|
const { refresh } = useRouter();
|
||
|
|
|
||
|
|
const onFocus = useCallback(() => {
|
||
|
|
refresh();
|
||
|
|
}, [refresh]);
|
||
|
|
|
||
|
|
useEffect(() => {
|
||
|
|
window.addEventListener('focus', onFocus);
|
||
|
|
|
||
|
|
return () => {
|
||
|
|
window.removeEventListener('focus', onFocus);
|
||
|
|
};
|
||
|
|
}, [onFocus]);
|
||
|
|
|
||
|
|
return null;
|
||
|
|
};
|