@tanstack/react-router
Version:
Modern and scalable routing for React applications
32 lines (31 loc) • 754 B
JavaScript
import * as React from "react";
import { useRouter } from "./useRouter.js";
function useNavigate(_defaultOpts) {
const router = useRouter();
return React.useCallback(
(options) => {
return router.navigate({
...options,
from: options.from ?? _defaultOpts?.from
});
},
[_defaultOpts?.from, router]
);
}
function Navigate(props) {
const router = useRouter();
const navigate = useNavigate();
const previousPropsRef = React.useRef(null);
React.useEffect(() => {
if (previousPropsRef.current !== props) {
navigate(props);
previousPropsRef.current = props;
}
}, [router, props, navigate]);
return null;
}
export {
Navigate,
useNavigate
};
//# sourceMappingURL=useNavigate.js.map