UNPKG

@tanstack/react-start

Version:

Modern and scalable routing for React applications

31 lines (25 loc) 732 B
import * as React from 'react' import { isRedirect, useRouter } from '@tanstack/react-router' export function useServerFn<T extends (...deps: Array<any>) => Promise<any>>( serverFn: T, ): (...args: Parameters<T>) => ReturnType<T> { const router = useRouter() return React.useCallback( async (...args: Array<any>) => { try { const res = await serverFn(...args) if (isRedirect(res)) { throw res } return res } catch (err) { if (isRedirect(err)) { err.options._fromLocation = router.state.location return router.navigate(router.resolveRedirect(err).options) } throw err } }, [router, serverFn], ) as any }