UNPKG

@tanstack/react-router

Version:

Modern and scalable routing for React applications

120 lines (119 loc) 3.9 kB
import { jsx, jsxs } from "react/jsx-runtime"; import * as React from "react"; import warning from "tiny-warning"; import { CatchBoundary, ErrorComponent } from "./CatchBoundary.js"; import { useRouterState } from "./useRouterState.js"; import { useRouter } from "./useRouter.js"; import { Transitioner } from "./Transitioner.js"; import { matchContext } from "./matchContext.js"; import { Match } from "./Match.js"; import { SafeFragment } from "./SafeFragment.js"; function Matches() { const router = useRouter(); const pendingElement = router.options.defaultPendingComponent ? /* @__PURE__ */ jsx(router.options.defaultPendingComponent, {}) : null; const ResolvedSuspense = router.isServer || typeof document !== "undefined" && router.clientSsr ? SafeFragment : React.Suspense; const inner = /* @__PURE__ */ jsxs(ResolvedSuspense, { fallback: pendingElement, children: [ /* @__PURE__ */ jsx(Transitioner, {}), /* @__PURE__ */ jsx(MatchesInner, {}) ] }); return router.options.InnerWrap ? /* @__PURE__ */ jsx(router.options.InnerWrap, { children: inner }) : inner; } function MatchesInner() { const matchId = useRouterState({ select: (s) => { var _a; return (_a = s.matches[0]) == null ? void 0 : _a.id; } }); const resetKey = useRouterState({ select: (s) => s.loadedAt }); return /* @__PURE__ */ jsx(matchContext.Provider, { value: matchId, children: /* @__PURE__ */ jsx( CatchBoundary, { getResetKey: () => resetKey, errorComponent: ErrorComponent, onCatch: (error) => { warning( false, `The following error wasn't caught by any route! At the very least, consider setting an 'errorComponent' in your RootRoute!` ); warning(false, error.message || error.toString()); }, children: matchId ? /* @__PURE__ */ jsx(Match, { matchId }) : null } ) }); } function useMatchRoute() { const router = useRouter(); useRouterState({ select: (s) => { var _a; return [s.location.href, (_a = s.resolvedLocation) == null ? void 0 : _a.href, s.status]; }, structuralSharing: true }); return React.useCallback( (opts) => { const { pending, caseSensitive, fuzzy, includeSearch, ...rest } = opts; return router.matchRoute(rest, { pending, caseSensitive, fuzzy, includeSearch }); }, [router] ); } function MatchRoute(props) { const matchRoute = useMatchRoute(); const params = matchRoute(props); if (typeof props.children === "function") { return props.children(params); } return params ? props.children : null; } function useMatches(opts) { return useRouterState({ select: (state) => { const matches = state.matches; return (opts == null ? void 0 : opts.select) ? opts.select(matches) : matches; }, structuralSharing: opts == null ? void 0 : opts.structuralSharing }); } function useParentMatches(opts) { const contextMatchId = React.useContext(matchContext); return useMatches({ select: (matches) => { matches = matches.slice( 0, matches.findIndex((d) => d.id === contextMatchId) ); return (opts == null ? void 0 : opts.select) ? opts.select(matches) : matches; }, structuralSharing: opts == null ? void 0 : opts.structuralSharing }); } function useChildMatches(opts) { const contextMatchId = React.useContext(matchContext); return useMatches({ select: (matches) => { matches = matches.slice( matches.findIndex((d) => d.id === contextMatchId) + 1 ); return (opts == null ? void 0 : opts.select) ? opts.select(matches) : matches; }, structuralSharing: opts == null ? void 0 : opts.structuralSharing }); } export { MatchRoute, Matches, useChildMatches, useMatchRoute, useMatches, useParentMatches }; //# sourceMappingURL=Matches.js.map