UNPKG

@toolpad/core

Version:

Dashboard framework powered by Material UI.

50 lines (49 loc) 1.3 kB
'use client'; import * as React from 'react'; import { useSearchParams, useLocation, useNavigate, Link as ReactRouterLink } from 'react-router'; import { AppProvider } from "../AppProvider/AppProvider.js"; import { jsx as _jsx } from "react/jsx-runtime"; const Link = /*#__PURE__*/React.forwardRef((props, ref) => { const { href, history, ...rest } = props; return /*#__PURE__*/_jsx(ReactRouterLink, { ref: ref, to: href, replace: history === 'replace', ...rest }); }); function ReactRouterAppProvider(props) { const { pathname } = useLocation(); const [searchParams] = useSearchParams(); const navigate = useNavigate(); const navigateImpl = React.useCallback((url, { history = 'auto' } = {}) => { if (history === 'auto' || history === 'push') { return navigate(url); } if (history === 'replace') { return navigate(url, { replace: true }); } throw new Error(`Invalid history option: ${history}`); }, [navigate]); const routerImpl = React.useMemo(() => ({ pathname, searchParams, navigate: navigateImpl, Link }), [pathname, searchParams, navigateImpl]); return /*#__PURE__*/_jsx(AppProvider, { router: routerImpl, ...props }); } export { ReactRouterAppProvider };