source: imaps-frontend/node_modules/react-router/dist/umd/react-router.development.js@ 0c6b92a

main
Last change on this file since 0c6b92a was 0c6b92a, checked in by stefan toskovski <stefantoska84@…>, 5 weeks ago

Pred finalna verzija

  • Property mode set to 100644
File size: 64.6 KB
RevLine 
[d565449]1/**
[0c6b92a]2 * React Router v6.28.0
[d565449]3 *
4 * Copyright (c) Remix Software Inc.
5 *
6 * This source code is licensed under the MIT license found in the
7 * LICENSE.md file in the root directory of this source tree.
8 *
9 * @license MIT
10 */
11(function (global, factory) {
12 typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('react'), require('@remix-run/router')) :
13 typeof define === 'function' && define.amd ? define(['exports', 'react', '@remix-run/router'], factory) :
14 (global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.ReactRouter = {}, global.React, global.RemixRouter));
15})(this, (function (exports, React, router) { 'use strict';
16
17 function _interopNamespace(e) {
18 if (e && e.__esModule) return e;
19 var n = Object.create(null);
20 if (e) {
21 Object.keys(e).forEach(function (k) {
22 if (k !== 'default') {
23 var d = Object.getOwnPropertyDescriptor(e, k);
24 Object.defineProperty(n, k, d.get ? d : {
25 enumerable: true,
26 get: function () { return e[k]; }
27 });
28 }
29 });
30 }
31 n["default"] = e;
32 return Object.freeze(n);
33 }
34
35 var React__namespace = /*#__PURE__*/_interopNamespace(React);
36
37 function _extends() {
38 _extends = Object.assign ? Object.assign.bind() : function (target) {
39 for (var i = 1; i < arguments.length; i++) {
40 var source = arguments[i];
41 for (var key in source) {
42 if (Object.prototype.hasOwnProperty.call(source, key)) {
43 target[key] = source[key];
44 }
45 }
46 }
47 return target;
48 };
49 return _extends.apply(this, arguments);
50 }
51
52 // Create react-specific types from the agnostic types in @remix-run/router to
53 // export from react-router
54 const DataRouterContext = /*#__PURE__*/React__namespace.createContext(null);
55 {
56 DataRouterContext.displayName = "DataRouter";
57 }
58 const DataRouterStateContext = /*#__PURE__*/React__namespace.createContext(null);
59 {
60 DataRouterStateContext.displayName = "DataRouterState";
61 }
62 const AwaitContext = /*#__PURE__*/React__namespace.createContext(null);
63 {
64 AwaitContext.displayName = "Await";
65 }
66
67 /**
68 * A Navigator is a "location changer"; it's how you get to different locations.
69 *
70 * Every history instance conforms to the Navigator interface, but the
71 * distinction is useful primarily when it comes to the low-level `<Router>` API
72 * where both the location and a navigator must be provided separately in order
73 * to avoid "tearing" that may occur in a suspense-enabled app if the action
74 * and/or location were to be read directly from the history instance.
75 */
76
77 const NavigationContext = /*#__PURE__*/React__namespace.createContext(null);
78 {
79 NavigationContext.displayName = "Navigation";
80 }
81 const LocationContext = /*#__PURE__*/React__namespace.createContext(null);
82 {
83 LocationContext.displayName = "Location";
84 }
85 const RouteContext = /*#__PURE__*/React__namespace.createContext({
86 outlet: null,
87 matches: [],
88 isDataRoute: false
89 });
90 {
91 RouteContext.displayName = "Route";
92 }
93 const RouteErrorContext = /*#__PURE__*/React__namespace.createContext(null);
94 {
95 RouteErrorContext.displayName = "RouteError";
96 }
97
98 /**
99 * Returns the full href for the given "to" value. This is useful for building
100 * custom links that are also accessible and preserve right-click behavior.
101 *
[0c6b92a]102 * @see https://reactrouter.com/v6/hooks/use-href
[d565449]103 */
104 function useHref(to, _temp) {
105 let {
106 relative
107 } = _temp === void 0 ? {} : _temp;
108 !useInRouterContext() ? router.UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the
109 // router loaded. We can help them understand how to avoid that.
110 "useHref() may be used only in the context of a <Router> component.") : void 0;
111 let {
112 basename,
113 navigator
114 } = React__namespace.useContext(NavigationContext);
115 let {
116 hash,
117 pathname,
118 search
119 } = useResolvedPath(to, {
120 relative
121 });
122 let joinedPathname = pathname;
123
124 // If we're operating within a basename, prepend it to the pathname prior
125 // to creating the href. If this is a root navigation, then just use the raw
126 // basename which allows the basename to have full control over the presence
127 // of a trailing slash on root links
128 if (basename !== "/") {
129 joinedPathname = pathname === "/" ? basename : router.joinPaths([basename, pathname]);
130 }
131 return navigator.createHref({
132 pathname: joinedPathname,
133 search,
134 hash
135 });
136 }
137
138 /**
139 * Returns true if this component is a descendant of a `<Router>`.
140 *
[0c6b92a]141 * @see https://reactrouter.com/v6/hooks/use-in-router-context
[d565449]142 */
143 function useInRouterContext() {
144 return React__namespace.useContext(LocationContext) != null;
145 }
146
147 /**
148 * Returns the current location object, which represents the current URL in web
149 * browsers.
150 *
151 * Note: If you're using this it may mean you're doing some of your own
152 * "routing" in your app, and we'd like to know what your use case is. We may
153 * be able to provide something higher-level to better suit your needs.
154 *
[0c6b92a]155 * @see https://reactrouter.com/v6/hooks/use-location
[d565449]156 */
157 function useLocation() {
158 !useInRouterContext() ? router.UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the
159 // router loaded. We can help them understand how to avoid that.
160 "useLocation() may be used only in the context of a <Router> component.") : void 0;
161 return React__namespace.useContext(LocationContext).location;
162 }
163
164 /**
165 * Returns the current navigation action which describes how the router came to
166 * the current location, either by a pop, push, or replace on the history stack.
167 *
[0c6b92a]168 * @see https://reactrouter.com/v6/hooks/use-navigation-type
[d565449]169 */
170 function useNavigationType() {
171 return React__namespace.useContext(LocationContext).navigationType;
172 }
173
174 /**
175 * Returns a PathMatch object if the given pattern matches the current URL.
176 * This is useful for components that need to know "active" state, e.g.
177 * `<NavLink>`.
178 *
[0c6b92a]179 * @see https://reactrouter.com/v6/hooks/use-match
[d565449]180 */
181 function useMatch(pattern) {
182 !useInRouterContext() ? router.UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the
183 // router loaded. We can help them understand how to avoid that.
184 "useMatch() may be used only in the context of a <Router> component.") : void 0;
185 let {
186 pathname
187 } = useLocation();
188 return React__namespace.useMemo(() => router.matchPath(pattern, router.UNSAFE_decodePath(pathname)), [pathname, pattern]);
189 }
190
191 /**
192 * The interface for the navigate() function returned from useNavigate().
193 */
194
195 const navigateEffectWarning = "You should call navigate() in a React.useEffect(), not when " + "your component is first rendered.";
196
197 // Mute warnings for calls to useNavigate in SSR environments
198 function useIsomorphicLayoutEffect(cb) {
199 let isStatic = React__namespace.useContext(NavigationContext).static;
200 if (!isStatic) {
201 // We should be able to get rid of this once react 18.3 is released
202 // See: https://github.com/facebook/react/pull/26395
203 // eslint-disable-next-line react-hooks/rules-of-hooks
204 React__namespace.useLayoutEffect(cb);
205 }
206 }
207
208 /**
209 * Returns an imperative method for changing the location. Used by `<Link>`s, but
210 * may also be used by other elements to change the location.
211 *
[0c6b92a]212 * @see https://reactrouter.com/v6/hooks/use-navigate
[d565449]213 */
214 function useNavigate() {
215 let {
216 isDataRoute
217 } = React__namespace.useContext(RouteContext);
218 // Conditional usage is OK here because the usage of a data router is static
219 // eslint-disable-next-line react-hooks/rules-of-hooks
220 return isDataRoute ? useNavigateStable() : useNavigateUnstable();
221 }
222 function useNavigateUnstable() {
223 !useInRouterContext() ? router.UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the
224 // router loaded. We can help them understand how to avoid that.
225 "useNavigate() may be used only in the context of a <Router> component.") : void 0;
226 let dataRouterContext = React__namespace.useContext(DataRouterContext);
227 let {
228 basename,
229 future,
230 navigator
231 } = React__namespace.useContext(NavigationContext);
232 let {
233 matches
234 } = React__namespace.useContext(RouteContext);
235 let {
236 pathname: locationPathname
237 } = useLocation();
238 let routePathnamesJson = JSON.stringify(router.UNSAFE_getResolveToMatches(matches, future.v7_relativeSplatPath));
239 let activeRef = React__namespace.useRef(false);
240 useIsomorphicLayoutEffect(() => {
241 activeRef.current = true;
242 });
243 let navigate = React__namespace.useCallback(function (to, options) {
244 if (options === void 0) {
245 options = {};
246 }
247 router.UNSAFE_warning(activeRef.current, navigateEffectWarning) ;
248
249 // Short circuit here since if this happens on first render the navigate
250 // is useless because we haven't wired up our history listener yet
251 if (!activeRef.current) return;
252 if (typeof to === "number") {
253 navigator.go(to);
254 return;
255 }
256 let path = router.resolveTo(to, JSON.parse(routePathnamesJson), locationPathname, options.relative === "path");
257
258 // If we're operating within a basename, prepend it to the pathname prior
259 // to handing off to history (but only if we're not in a data router,
260 // otherwise it'll prepend the basename inside of the router).
261 // If this is a root navigation, then we navigate to the raw basename
262 // which allows the basename to have full control over the presence of a
263 // trailing slash on root links
264 if (dataRouterContext == null && basename !== "/") {
265 path.pathname = path.pathname === "/" ? basename : router.joinPaths([basename, path.pathname]);
266 }
267 (!!options.replace ? navigator.replace : navigator.push)(path, options.state, options);
268 }, [basename, navigator, routePathnamesJson, locationPathname, dataRouterContext]);
269 return navigate;
270 }
271 const OutletContext = /*#__PURE__*/React__namespace.createContext(null);
272
273 /**
274 * Returns the context (if provided) for the child route at this level of the route
275 * hierarchy.
[0c6b92a]276 * @see https://reactrouter.com/v6/hooks/use-outlet-context
[d565449]277 */
278 function useOutletContext() {
279 return React__namespace.useContext(OutletContext);
280 }
281
282 /**
283 * Returns the element for the child route at this level of the route
284 * hierarchy. Used internally by `<Outlet>` to render child routes.
285 *
[0c6b92a]286 * @see https://reactrouter.com/v6/hooks/use-outlet
[d565449]287 */
288 function useOutlet(context) {
289 let outlet = React__namespace.useContext(RouteContext).outlet;
290 if (outlet) {
291 return /*#__PURE__*/React__namespace.createElement(OutletContext.Provider, {
292 value: context
293 }, outlet);
294 }
295 return outlet;
296 }
297
298 /**
299 * Returns an object of key/value pairs of the dynamic params from the current
300 * URL that were matched by the route path.
301 *
[0c6b92a]302 * @see https://reactrouter.com/v6/hooks/use-params
[d565449]303 */
304 function useParams() {
305 let {
306 matches
307 } = React__namespace.useContext(RouteContext);
308 let routeMatch = matches[matches.length - 1];
309 return routeMatch ? routeMatch.params : {};
310 }
311
312 /**
313 * Resolves the pathname of the given `to` value against the current location.
314 *
[0c6b92a]315 * @see https://reactrouter.com/v6/hooks/use-resolved-path
[d565449]316 */
317 function useResolvedPath(to, _temp2) {
318 let {
319 relative
320 } = _temp2 === void 0 ? {} : _temp2;
321 let {
322 future
323 } = React__namespace.useContext(NavigationContext);
324 let {
325 matches
326 } = React__namespace.useContext(RouteContext);
327 let {
328 pathname: locationPathname
329 } = useLocation();
330 let routePathnamesJson = JSON.stringify(router.UNSAFE_getResolveToMatches(matches, future.v7_relativeSplatPath));
331 return React__namespace.useMemo(() => router.resolveTo(to, JSON.parse(routePathnamesJson), locationPathname, relative === "path"), [to, routePathnamesJson, locationPathname, relative]);
332 }
333
334 /**
335 * Returns the element of the route that matched the current location, prepared
336 * with the correct context to render the remainder of the route tree. Route
337 * elements in the tree must render an `<Outlet>` to render their child route's
338 * element.
339 *
[0c6b92a]340 * @see https://reactrouter.com/v6/hooks/use-routes
[d565449]341 */
342 function useRoutes(routes, locationArg) {
343 return useRoutesImpl(routes, locationArg);
344 }
345
346 // Internal implementation with accept optional param for RouterProvider usage
347 function useRoutesImpl(routes, locationArg, dataRouterState, future) {
348 !useInRouterContext() ? router.UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the
349 // router loaded. We can help them understand how to avoid that.
350 "useRoutes() may be used only in the context of a <Router> component.") : void 0;
351 let {
352 navigator
353 } = React__namespace.useContext(NavigationContext);
354 let {
355 matches: parentMatches
356 } = React__namespace.useContext(RouteContext);
357 let routeMatch = parentMatches[parentMatches.length - 1];
358 let parentParams = routeMatch ? routeMatch.params : {};
359 let parentPathname = routeMatch ? routeMatch.pathname : "/";
360 let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : "/";
361 let parentRoute = routeMatch && routeMatch.route;
362 {
363 // You won't get a warning about 2 different <Routes> under a <Route>
364 // without a trailing *, but this is a best-effort warning anyway since we
365 // cannot even give the warning unless they land at the parent route.
366 //
367 // Example:
368 //
369 // <Routes>
370 // {/* This route path MUST end with /* because otherwise
371 // it will never match /blog/post/123 */}
372 // <Route path="blog" element={<Blog />} />
373 // <Route path="blog/feed" element={<BlogFeed />} />
374 // </Routes>
375 //
376 // function Blog() {
377 // return (
378 // <Routes>
379 // <Route path="post/:id" element={<Post />} />
380 // </Routes>
381 // );
382 // }
383 let parentPath = parentRoute && parentRoute.path || "";
384 warningOnce(parentPathname, !parentRoute || parentPath.endsWith("*"), "You rendered descendant <Routes> (or called `useRoutes()`) at " + ("\"" + parentPathname + "\" (under <Route path=\"" + parentPath + "\">) but the ") + "parent route path has no trailing \"*\". This means if you navigate " + "deeper, the parent won't match anymore and therefore the child " + "routes will never render.\n\n" + ("Please change the parent <Route path=\"" + parentPath + "\"> to <Route ") + ("path=\"" + (parentPath === "/" ? "*" : parentPath + "/*") + "\">."));
385 }
386 let locationFromContext = useLocation();
387 let location;
388 if (locationArg) {
389 var _parsedLocationArg$pa;
390 let parsedLocationArg = typeof locationArg === "string" ? router.parsePath(locationArg) : locationArg;
391 !(parentPathnameBase === "/" || ((_parsedLocationArg$pa = parsedLocationArg.pathname) == null ? void 0 : _parsedLocationArg$pa.startsWith(parentPathnameBase))) ? router.UNSAFE_invariant(false, "When overriding the location using `<Routes location>` or `useRoutes(routes, location)`, " + "the location pathname must begin with the portion of the URL pathname that was " + ("matched by all parent routes. The current pathname base is \"" + parentPathnameBase + "\" ") + ("but pathname \"" + parsedLocationArg.pathname + "\" was given in the `location` prop.")) : void 0;
392 location = parsedLocationArg;
393 } else {
394 location = locationFromContext;
395 }
396 let pathname = location.pathname || "/";
397 let remainingPathname = pathname;
398 if (parentPathnameBase !== "/") {
399 // Determine the remaining pathname by removing the # of URL segments the
400 // parentPathnameBase has, instead of removing based on character count.
401 // This is because we can't guarantee that incoming/outgoing encodings/
402 // decodings will match exactly.
403 // We decode paths before matching on a per-segment basis with
404 // decodeURIComponent(), but we re-encode pathnames via `new URL()` so they
405 // match what `window.location.pathname` would reflect. Those don't 100%
406 // align when it comes to encoded URI characters such as % and &.
407 //
408 // So we may end up with:
409 // pathname: "/descendant/a%25b/match"
410 // parentPathnameBase: "/descendant/a%b"
411 //
412 // And the direct substring removal approach won't work :/
413 let parentSegments = parentPathnameBase.replace(/^\//, "").split("/");
414 let segments = pathname.replace(/^\//, "").split("/");
415 remainingPathname = "/" + segments.slice(parentSegments.length).join("/");
416 }
417 let matches = router.matchRoutes(routes, {
418 pathname: remainingPathname
419 });
420 {
421 router.UNSAFE_warning(parentRoute || matches != null, "No routes matched location \"" + location.pathname + location.search + location.hash + "\" ") ;
422 router.UNSAFE_warning(matches == null || matches[matches.length - 1].route.element !== undefined || matches[matches.length - 1].route.Component !== undefined || matches[matches.length - 1].route.lazy !== undefined, "Matched leaf route at location \"" + location.pathname + location.search + location.hash + "\" " + "does not have an element or Component. This means it will render an <Outlet /> with a " + "null value by default resulting in an \"empty\" page.") ;
423 }
424 let renderedMatches = _renderMatches(matches && matches.map(match => Object.assign({}, match, {
425 params: Object.assign({}, parentParams, match.params),
426 pathname: router.joinPaths([parentPathnameBase,
427 // Re-encode pathnames that were decoded inside matchRoutes
428 navigator.encodeLocation ? navigator.encodeLocation(match.pathname).pathname : match.pathname]),
429 pathnameBase: match.pathnameBase === "/" ? parentPathnameBase : router.joinPaths([parentPathnameBase,
430 // Re-encode pathnames that were decoded inside matchRoutes
431 navigator.encodeLocation ? navigator.encodeLocation(match.pathnameBase).pathname : match.pathnameBase])
432 })), parentMatches, dataRouterState, future);
433
434 // When a user passes in a `locationArg`, the associated routes need to
435 // be wrapped in a new `LocationContext.Provider` in order for `useLocation`
436 // to use the scoped location instead of the global location.
437 if (locationArg && renderedMatches) {
438 return /*#__PURE__*/React__namespace.createElement(LocationContext.Provider, {
439 value: {
440 location: _extends({
441 pathname: "/",
442 search: "",
443 hash: "",
444 state: null,
445 key: "default"
446 }, location),
447 navigationType: router.Action.Pop
448 }
449 }, renderedMatches);
450 }
451 return renderedMatches;
452 }
453 function DefaultErrorComponent() {
454 let error = useRouteError();
455 let message = router.isRouteErrorResponse(error) ? error.status + " " + error.statusText : error instanceof Error ? error.message : JSON.stringify(error);
456 let stack = error instanceof Error ? error.stack : null;
457 let lightgrey = "rgba(200,200,200, 0.5)";
458 let preStyles = {
459 padding: "0.5rem",
460 backgroundColor: lightgrey
461 };
462 let codeStyles = {
463 padding: "2px 4px",
464 backgroundColor: lightgrey
465 };
466 let devInfo = null;
467 {
468 console.error("Error handled by React Router default ErrorBoundary:", error);
469 devInfo = /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, /*#__PURE__*/React__namespace.createElement("p", null, "\uD83D\uDCBF Hey developer \uD83D\uDC4B"), /*#__PURE__*/React__namespace.createElement("p", null, "You can provide a way better UX than this when your app throws errors by providing your own ", /*#__PURE__*/React__namespace.createElement("code", {
470 style: codeStyles
471 }, "ErrorBoundary"), " or", " ", /*#__PURE__*/React__namespace.createElement("code", {
472 style: codeStyles
473 }, "errorElement"), " prop on your route."));
474 }
475 return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, /*#__PURE__*/React__namespace.createElement("h2", null, "Unexpected Application Error!"), /*#__PURE__*/React__namespace.createElement("h3", {
476 style: {
477 fontStyle: "italic"
478 }
479 }, message), stack ? /*#__PURE__*/React__namespace.createElement("pre", {
480 style: preStyles
481 }, stack) : null, devInfo);
482 }
483 const defaultErrorElement = /*#__PURE__*/React__namespace.createElement(DefaultErrorComponent, null);
484 class RenderErrorBoundary extends React__namespace.Component {
485 constructor(props) {
486 super(props);
487 this.state = {
488 location: props.location,
489 revalidation: props.revalidation,
490 error: props.error
491 };
492 }
493 static getDerivedStateFromError(error) {
494 return {
495 error: error
496 };
497 }
498 static getDerivedStateFromProps(props, state) {
499 // When we get into an error state, the user will likely click "back" to the
500 // previous page that didn't have an error. Because this wraps the entire
501 // application, that will have no effect--the error page continues to display.
502 // This gives us a mechanism to recover from the error when the location changes.
503 //
504 // Whether we're in an error state or not, we update the location in state
505 // so that when we are in an error state, it gets reset when a new location
506 // comes in and the user recovers from the error.
507 if (state.location !== props.location || state.revalidation !== "idle" && props.revalidation === "idle") {
508 return {
509 error: props.error,
510 location: props.location,
511 revalidation: props.revalidation
512 };
513 }
514
515 // If we're not changing locations, preserve the location but still surface
516 // any new errors that may come through. We retain the existing error, we do
517 // this because the error provided from the app state may be cleared without
518 // the location changing.
519 return {
520 error: props.error !== undefined ? props.error : state.error,
521 location: state.location,
522 revalidation: props.revalidation || state.revalidation
523 };
524 }
525 componentDidCatch(error, errorInfo) {
526 console.error("React Router caught the following error during render", error, errorInfo);
527 }
528 render() {
529 return this.state.error !== undefined ? /*#__PURE__*/React__namespace.createElement(RouteContext.Provider, {
530 value: this.props.routeContext
531 }, /*#__PURE__*/React__namespace.createElement(RouteErrorContext.Provider, {
532 value: this.state.error,
533 children: this.props.component
534 })) : this.props.children;
535 }
536 }
537 function RenderedRoute(_ref) {
538 let {
539 routeContext,
540 match,
541 children
542 } = _ref;
543 let dataRouterContext = React__namespace.useContext(DataRouterContext);
544
545 // Track how deep we got in our render pass to emulate SSR componentDidCatch
546 // in a DataStaticRouter
547 if (dataRouterContext && dataRouterContext.static && dataRouterContext.staticContext && (match.route.errorElement || match.route.ErrorBoundary)) {
548 dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;
549 }
550 return /*#__PURE__*/React__namespace.createElement(RouteContext.Provider, {
551 value: routeContext
552 }, children);
553 }
554 function _renderMatches(matches, parentMatches, dataRouterState, future) {
555 var _dataRouterState;
556 if (parentMatches === void 0) {
557 parentMatches = [];
558 }
559 if (dataRouterState === void 0) {
560 dataRouterState = null;
561 }
562 if (future === void 0) {
563 future = null;
564 }
565 if (matches == null) {
566 var _future;
567 if (!dataRouterState) {
568 return null;
569 }
570 if (dataRouterState.errors) {
571 // Don't bail if we have data router errors so we can render them in the
572 // boundary. Use the pre-matched (or shimmed) matches
573 matches = dataRouterState.matches;
574 } else if ((_future = future) != null && _future.v7_partialHydration && parentMatches.length === 0 && !dataRouterState.initialized && dataRouterState.matches.length > 0) {
575 // Don't bail if we're initializing with partial hydration and we have
[0c6b92a]576 // router matches. That means we're actively running `patchRoutesOnNavigation`
[d565449]577 // so we should render down the partial matches to the appropriate
578 // `HydrateFallback`. We only do this if `parentMatches` is empty so it
579 // only impacts the root matches for `RouterProvider` and no descendant
580 // `<Routes>`
581 matches = dataRouterState.matches;
582 } else {
583 return null;
584 }
585 }
586 let renderedMatches = matches;
587
588 // If we have data errors, trim matches to the highest error boundary
589 let errors = (_dataRouterState = dataRouterState) == null ? void 0 : _dataRouterState.errors;
590 if (errors != null) {
591 let errorIndex = renderedMatches.findIndex(m => m.route.id && (errors == null ? void 0 : errors[m.route.id]) !== undefined);
592 !(errorIndex >= 0) ? router.UNSAFE_invariant(false, "Could not find a matching route for errors on route IDs: " + Object.keys(errors).join(",")) : void 0;
593 renderedMatches = renderedMatches.slice(0, Math.min(renderedMatches.length, errorIndex + 1));
594 }
595
596 // If we're in a partial hydration mode, detect if we need to render down to
597 // a given HydrateFallback while we load the rest of the hydration data
598 let renderFallback = false;
599 let fallbackIndex = -1;
600 if (dataRouterState && future && future.v7_partialHydration) {
601 for (let i = 0; i < renderedMatches.length; i++) {
602 let match = renderedMatches[i];
603 // Track the deepest fallback up until the first route without data
604 if (match.route.HydrateFallback || match.route.hydrateFallbackElement) {
605 fallbackIndex = i;
606 }
607 if (match.route.id) {
608 let {
609 loaderData,
610 errors
611 } = dataRouterState;
612 let needsToRunLoader = match.route.loader && loaderData[match.route.id] === undefined && (!errors || errors[match.route.id] === undefined);
613 if (match.route.lazy || needsToRunLoader) {
614 // We found the first route that's not ready to render (waiting on
615 // lazy, or has a loader that hasn't run yet). Flag that we need to
616 // render a fallback and render up until the appropriate fallback
617 renderFallback = true;
618 if (fallbackIndex >= 0) {
619 renderedMatches = renderedMatches.slice(0, fallbackIndex + 1);
620 } else {
621 renderedMatches = [renderedMatches[0]];
622 }
623 break;
624 }
625 }
626 }
627 }
628 return renderedMatches.reduceRight((outlet, match, index) => {
629 // Only data routers handle errors/fallbacks
630 let error;
631 let shouldRenderHydrateFallback = false;
632 let errorElement = null;
633 let hydrateFallbackElement = null;
634 if (dataRouterState) {
635 error = errors && match.route.id ? errors[match.route.id] : undefined;
636 errorElement = match.route.errorElement || defaultErrorElement;
637 if (renderFallback) {
638 if (fallbackIndex < 0 && index === 0) {
639 warningOnce("route-fallback", false, "No `HydrateFallback` element provided to render during initial hydration");
640 shouldRenderHydrateFallback = true;
641 hydrateFallbackElement = null;
642 } else if (fallbackIndex === index) {
643 shouldRenderHydrateFallback = true;
644 hydrateFallbackElement = match.route.hydrateFallbackElement || null;
645 }
646 }
647 }
648 let matches = parentMatches.concat(renderedMatches.slice(0, index + 1));
649 let getChildren = () => {
650 let children;
651 if (error) {
652 children = errorElement;
653 } else if (shouldRenderHydrateFallback) {
654 children = hydrateFallbackElement;
655 } else if (match.route.Component) {
656 // Note: This is a de-optimized path since React won't re-use the
657 // ReactElement since it's identity changes with each new
658 // React.createElement call. We keep this so folks can use
659 // `<Route Component={...}>` in `<Routes>` but generally `Component`
660 // usage is only advised in `RouterProvider` when we can convert it to
661 // `element` ahead of time.
662 children = /*#__PURE__*/React__namespace.createElement(match.route.Component, null);
663 } else if (match.route.element) {
664 children = match.route.element;
665 } else {
666 children = outlet;
667 }
668 return /*#__PURE__*/React__namespace.createElement(RenderedRoute, {
669 match: match,
670 routeContext: {
671 outlet,
672 matches,
673 isDataRoute: dataRouterState != null
674 },
675 children: children
676 });
677 };
678 // Only wrap in an error boundary within data router usages when we have an
679 // ErrorBoundary/errorElement on this route. Otherwise let it bubble up to
680 // an ancestor ErrorBoundary/errorElement
681 return dataRouterState && (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? /*#__PURE__*/React__namespace.createElement(RenderErrorBoundary, {
682 location: dataRouterState.location,
683 revalidation: dataRouterState.revalidation,
684 component: errorElement,
685 error: error,
686 children: getChildren(),
687 routeContext: {
688 outlet: null,
689 matches,
690 isDataRoute: true
691 }
692 }) : getChildren();
693 }, null);
694 }
695 var DataRouterHook = /*#__PURE__*/function (DataRouterHook) {
696 DataRouterHook["UseBlocker"] = "useBlocker";
697 DataRouterHook["UseRevalidator"] = "useRevalidator";
698 DataRouterHook["UseNavigateStable"] = "useNavigate";
699 return DataRouterHook;
700 }(DataRouterHook || {});
701 var DataRouterStateHook = /*#__PURE__*/function (DataRouterStateHook) {
702 DataRouterStateHook["UseBlocker"] = "useBlocker";
703 DataRouterStateHook["UseLoaderData"] = "useLoaderData";
704 DataRouterStateHook["UseActionData"] = "useActionData";
705 DataRouterStateHook["UseRouteError"] = "useRouteError";
706 DataRouterStateHook["UseNavigation"] = "useNavigation";
707 DataRouterStateHook["UseRouteLoaderData"] = "useRouteLoaderData";
708 DataRouterStateHook["UseMatches"] = "useMatches";
709 DataRouterStateHook["UseRevalidator"] = "useRevalidator";
710 DataRouterStateHook["UseNavigateStable"] = "useNavigate";
711 DataRouterStateHook["UseRouteId"] = "useRouteId";
712 return DataRouterStateHook;
713 }(DataRouterStateHook || {});
714 function getDataRouterConsoleError(hookName) {
[0c6b92a]715 return hookName + " must be used within a data router. See https://reactrouter.com/v6/routers/picking-a-router.";
[d565449]716 }
717 function useDataRouterContext(hookName) {
718 let ctx = React__namespace.useContext(DataRouterContext);
719 !ctx ? router.UNSAFE_invariant(false, getDataRouterConsoleError(hookName)) : void 0;
720 return ctx;
721 }
722 function useDataRouterState(hookName) {
723 let state = React__namespace.useContext(DataRouterStateContext);
724 !state ? router.UNSAFE_invariant(false, getDataRouterConsoleError(hookName)) : void 0;
725 return state;
726 }
727 function useRouteContext(hookName) {
728 let route = React__namespace.useContext(RouteContext);
729 !route ? router.UNSAFE_invariant(false, getDataRouterConsoleError(hookName)) : void 0;
730 return route;
731 }
732
733 // Internal version with hookName-aware debugging
734 function useCurrentRouteId(hookName) {
735 let route = useRouteContext(hookName);
736 let thisRoute = route.matches[route.matches.length - 1];
737 !thisRoute.route.id ? router.UNSAFE_invariant(false, hookName + " can only be used on routes that contain a unique \"id\"") : void 0;
738 return thisRoute.route.id;
739 }
740
741 /**
742 * Returns the ID for the nearest contextual route
743 */
744 function useRouteId() {
745 return useCurrentRouteId(DataRouterStateHook.UseRouteId);
746 }
747
748 /**
749 * Returns the current navigation, defaulting to an "idle" navigation when
750 * no navigation is in progress
751 */
752 function useNavigation() {
753 let state = useDataRouterState(DataRouterStateHook.UseNavigation);
754 return state.navigation;
755 }
756
757 /**
758 * Returns a revalidate function for manually triggering revalidation, as well
759 * as the current state of any manual revalidations
760 */
761 function useRevalidator() {
762 let dataRouterContext = useDataRouterContext(DataRouterHook.UseRevalidator);
763 let state = useDataRouterState(DataRouterStateHook.UseRevalidator);
764 return React__namespace.useMemo(() => ({
765 revalidate: dataRouterContext.router.revalidate,
766 state: state.revalidation
767 }), [dataRouterContext.router.revalidate, state.revalidation]);
768 }
769
770 /**
771 * Returns the active route matches, useful for accessing loaderData for
772 * parent/child routes or the route "handle" property
773 */
774 function useMatches() {
775 let {
776 matches,
777 loaderData
778 } = useDataRouterState(DataRouterStateHook.UseMatches);
779 return React__namespace.useMemo(() => matches.map(m => router.UNSAFE_convertRouteMatchToUiMatch(m, loaderData)), [matches, loaderData]);
780 }
781
782 /**
783 * Returns the loader data for the nearest ancestor Route loader
784 */
785 function useLoaderData() {
786 let state = useDataRouterState(DataRouterStateHook.UseLoaderData);
787 let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);
788 if (state.errors && state.errors[routeId] != null) {
789 console.error("You cannot `useLoaderData` in an errorElement (routeId: " + routeId + ")");
790 return undefined;
791 }
792 return state.loaderData[routeId];
793 }
794
795 /**
796 * Returns the loaderData for the given routeId
797 */
798 function useRouteLoaderData(routeId) {
799 let state = useDataRouterState(DataRouterStateHook.UseRouteLoaderData);
800 return state.loaderData[routeId];
801 }
802
803 /**
804 * Returns the action data for the nearest ancestor Route action
805 */
806 function useActionData() {
807 let state = useDataRouterState(DataRouterStateHook.UseActionData);
808 let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);
809 return state.actionData ? state.actionData[routeId] : undefined;
810 }
811
812 /**
813 * Returns the nearest ancestor Route error, which could be a loader/action
814 * error or a render error. This is intended to be called from your
815 * ErrorBoundary/errorElement to display a proper error message.
816 */
817 function useRouteError() {
818 var _state$errors;
819 let error = React__namespace.useContext(RouteErrorContext);
820 let state = useDataRouterState(DataRouterStateHook.UseRouteError);
821 let routeId = useCurrentRouteId(DataRouterStateHook.UseRouteError);
822
823 // If this was a render error, we put it in a RouteError context inside
824 // of RenderErrorBoundary
825 if (error !== undefined) {
826 return error;
827 }
828
829 // Otherwise look for errors from our data router state
830 return (_state$errors = state.errors) == null ? void 0 : _state$errors[routeId];
831 }
832
833 /**
834 * Returns the happy-path data from the nearest ancestor `<Await />` value
835 */
836 function useAsyncValue() {
837 let value = React__namespace.useContext(AwaitContext);
838 return value == null ? void 0 : value._data;
839 }
840
841 /**
842 * Returns the error from the nearest ancestor `<Await />` value
843 */
844 function useAsyncError() {
845 let value = React__namespace.useContext(AwaitContext);
846 return value == null ? void 0 : value._error;
847 }
848 let blockerId = 0;
849
850 /**
851 * Allow the application to block navigations within the SPA and present the
852 * user a confirmation dialog to confirm the navigation. Mostly used to avoid
853 * using half-filled form data. This does not handle hard-reloads or
854 * cross-origin navigations.
855 */
856 function useBlocker(shouldBlock) {
857 let {
858 router: router$1,
859 basename
860 } = useDataRouterContext(DataRouterHook.UseBlocker);
861 let state = useDataRouterState(DataRouterStateHook.UseBlocker);
862 let [blockerKey, setBlockerKey] = React__namespace.useState("");
863 let blockerFunction = React__namespace.useCallback(arg => {
864 if (typeof shouldBlock !== "function") {
865 return !!shouldBlock;
866 }
867 if (basename === "/") {
868 return shouldBlock(arg);
869 }
870
871 // If they provided us a function and we've got an active basename, strip
872 // it from the locations we expose to the user to match the behavior of
873 // useLocation
874 let {
875 currentLocation,
876 nextLocation,
877 historyAction
878 } = arg;
879 return shouldBlock({
880 currentLocation: _extends({}, currentLocation, {
881 pathname: router.stripBasename(currentLocation.pathname, basename) || currentLocation.pathname
882 }),
883 nextLocation: _extends({}, nextLocation, {
884 pathname: router.stripBasename(nextLocation.pathname, basename) || nextLocation.pathname
885 }),
886 historyAction
887 });
888 }, [basename, shouldBlock]);
889
890 // This effect is in charge of blocker key assignment and deletion (which is
891 // tightly coupled to the key)
892 React__namespace.useEffect(() => {
893 let key = String(++blockerId);
894 setBlockerKey(key);
895 return () => router$1.deleteBlocker(key);
896 }, [router$1]);
897
898 // This effect handles assigning the blockerFunction. This is to handle
899 // unstable blocker function identities, and happens only after the prior
900 // effect so we don't get an orphaned blockerFunction in the router with a
901 // key of "". Until then we just have the IDLE_BLOCKER.
902 React__namespace.useEffect(() => {
903 if (blockerKey !== "") {
904 router$1.getBlocker(blockerKey, blockerFunction);
905 }
906 }, [router$1, blockerKey, blockerFunction]);
907
908 // Prefer the blocker from `state` not `router.state` since DataRouterContext
909 // is memoized so this ensures we update on blocker state updates
910 return blockerKey && state.blockers.has(blockerKey) ? state.blockers.get(blockerKey) : router.IDLE_BLOCKER;
911 }
912
913 /**
914 * Stable version of useNavigate that is used when we are in the context of
915 * a RouterProvider.
916 */
917 function useNavigateStable() {
918 let {
919 router: router$1
920 } = useDataRouterContext(DataRouterHook.UseNavigateStable);
921 let id = useCurrentRouteId(DataRouterStateHook.UseNavigateStable);
922 let activeRef = React__namespace.useRef(false);
923 useIsomorphicLayoutEffect(() => {
924 activeRef.current = true;
925 });
926 let navigate = React__namespace.useCallback(function (to, options) {
927 if (options === void 0) {
928 options = {};
929 }
930 router.UNSAFE_warning(activeRef.current, navigateEffectWarning) ;
931
932 // Short circuit here since if this happens on first render the navigate
933 // is useless because we haven't wired up our router subscriber yet
934 if (!activeRef.current) return;
935 if (typeof to === "number") {
936 router$1.navigate(to);
937 } else {
938 router$1.navigate(to, _extends({
939 fromRouteId: id
940 }, options));
941 }
942 }, [router$1, id]);
943 return navigate;
944 }
[0c6b92a]945 const alreadyWarned$1 = {};
[d565449]946 function warningOnce(key, cond, message) {
[0c6b92a]947 if (!cond && !alreadyWarned$1[key]) {
948 alreadyWarned$1[key] = true;
[d565449]949 router.UNSAFE_warning(false, message) ;
950 }
951 }
952
[0c6b92a]953 const alreadyWarned = {};
954 function warnOnce(key, message) {
955 if (!alreadyWarned[message]) {
956 alreadyWarned[message] = true;
957 console.warn(message);
958 }
959 }
960 const logDeprecation = (flag, msg, link) => warnOnce(flag, "\u26A0\uFE0F React Router Future Flag Warning: " + msg + ". " + ("You can use the `" + flag + "` future flag to opt-in early. ") + ("For more information, see " + link + "."));
961 function logV6DeprecationWarnings(renderFuture, routerFuture) {
962 if (!(renderFuture != null && renderFuture.v7_startTransition)) {
963 logDeprecation("v7_startTransition", "React Router will begin wrapping state updates in `React.startTransition` in v7", "https://reactrouter.com/v6/upgrading/future#v7_starttransition");
964 }
965 if (!(renderFuture != null && renderFuture.v7_relativeSplatPath) && (!routerFuture || !routerFuture.v7_relativeSplatPath)) {
966 logDeprecation("v7_relativeSplatPath", "Relative route resolution within Splat routes is changing in v7", "https://reactrouter.com/v6/upgrading/future#v7_relativesplatpath");
967 }
968 if (routerFuture) {
969 if (!routerFuture.v7_fetcherPersist) {
970 logDeprecation("v7_fetcherPersist", "The persistence behavior of fetchers is changing in v7", "https://reactrouter.com/v6/upgrading/future#v7_fetcherpersist");
971 }
972 if (!routerFuture.v7_normalizeFormMethod) {
973 logDeprecation("v7_normalizeFormMethod", "Casing of `formMethod` fields is being normalized to uppercase in v7", "https://reactrouter.com/v6/upgrading/future#v7_normalizeformmethod");
974 }
975 if (!routerFuture.v7_partialHydration) {
976 logDeprecation("v7_partialHydration", "`RouterProvider` hydration behavior is changing in v7", "https://reactrouter.com/v6/upgrading/future#v7_partialhydration");
977 }
978 if (!routerFuture.v7_skipActionErrorRevalidation) {
979 logDeprecation("v7_skipActionErrorRevalidation", "The revalidation behavior after 4xx/5xx `action` responses is changing in v7", "https://reactrouter.com/v6/upgrading/future#v7_skipactionerrorrevalidation");
980 }
981 }
982 }
983
[d565449]984 /**
985 Webpack + React 17 fails to compile on any of the following because webpack
986 complains that `startTransition` doesn't exist in `React`:
987 * import { startTransition } from "react"
988 * import * as React from from "react";
989 "startTransition" in React ? React.startTransition(() => setState()) : setState()
990 * import * as React from from "react";
991 "startTransition" in React ? React["startTransition"](() => setState()) : setState()
992
993 Moving it to a constant such as the following solves the Webpack/React 17 issue:
994 * import * as React from from "react";
995 const START_TRANSITION = "startTransition";
996 START_TRANSITION in React ? React[START_TRANSITION](() => setState()) : setState()
997
998 However, that introduces webpack/terser minification issues in production builds
999 in React 18 where minification/obfuscation ends up removing the call of
1000 React.startTransition entirely from the first half of the ternary. Grabbing
1001 this exported reference once up front resolves that issue.
1002
1003 See https://github.com/remix-run/react-router/issues/10579
1004 */
1005 const START_TRANSITION = "startTransition";
1006 const startTransitionImpl = React__namespace[START_TRANSITION];
1007
1008 /**
1009 * Given a Remix Router instance, render the appropriate UI
1010 */
1011 function RouterProvider(_ref) {
1012 let {
1013 fallbackElement,
1014 router: router$1,
1015 future
1016 } = _ref;
1017 let [state, setStateImpl] = React__namespace.useState(router$1.state);
1018 let {
1019 v7_startTransition
1020 } = future || {};
1021 let setState = React__namespace.useCallback(newState => {
1022 if (v7_startTransition && startTransitionImpl) {
1023 startTransitionImpl(() => setStateImpl(newState));
1024 } else {
1025 setStateImpl(newState);
1026 }
1027 }, [setStateImpl, v7_startTransition]);
1028
1029 // Need to use a layout effect here so we are subscribed early enough to
1030 // pick up on any render-driven redirects/navigations (useEffect/<Navigate>)
1031 React__namespace.useLayoutEffect(() => router$1.subscribe(setState), [router$1, setState]);
1032 React__namespace.useEffect(() => {
1033 router.UNSAFE_warning(fallbackElement == null || !router$1.future.v7_partialHydration, "`<RouterProvider fallbackElement>` is deprecated when using " + "`v7_partialHydration`, use a `HydrateFallback` component instead") ;
1034 // Only log this once on initial mount
1035 // eslint-disable-next-line react-hooks/exhaustive-deps
1036 }, []);
1037 let navigator = React__namespace.useMemo(() => {
1038 return {
1039 createHref: router$1.createHref,
1040 encodeLocation: router$1.encodeLocation,
1041 go: n => router$1.navigate(n),
1042 push: (to, state, opts) => router$1.navigate(to, {
1043 state,
1044 preventScrollReset: opts == null ? void 0 : opts.preventScrollReset
1045 }),
1046 replace: (to, state, opts) => router$1.navigate(to, {
1047 replace: true,
1048 state,
1049 preventScrollReset: opts == null ? void 0 : opts.preventScrollReset
1050 })
1051 };
1052 }, [router$1]);
1053 let basename = router$1.basename || "/";
1054 let dataRouterContext = React__namespace.useMemo(() => ({
1055 router: router$1,
1056 navigator,
1057 static: false,
1058 basename
1059 }), [router$1, navigator, basename]);
[0c6b92a]1060 React__namespace.useEffect(() => logV6DeprecationWarnings(future, router$1.future), [router$1, future]);
[d565449]1061
1062 // The fragment and {null} here are important! We need them to keep React 18's
1063 // useId happy when we are server-rendering since we may have a <script> here
1064 // containing the hydrated server-side staticContext (from StaticRouterProvider).
1065 // useId relies on the component tree structure to generate deterministic id's
1066 // so we need to ensure it remains the same on the client even though
1067 // we don't need the <script> tag
1068 return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, /*#__PURE__*/React__namespace.createElement(DataRouterContext.Provider, {
1069 value: dataRouterContext
1070 }, /*#__PURE__*/React__namespace.createElement(DataRouterStateContext.Provider, {
1071 value: state
1072 }, /*#__PURE__*/React__namespace.createElement(Router, {
1073 basename: basename,
1074 location: state.location,
1075 navigationType: state.historyAction,
1076 navigator: navigator,
1077 future: {
1078 v7_relativeSplatPath: router$1.future.v7_relativeSplatPath
1079 }
1080 }, state.initialized || router$1.future.v7_partialHydration ? /*#__PURE__*/React__namespace.createElement(DataRoutes, {
1081 routes: router$1.routes,
1082 future: router$1.future,
1083 state: state
1084 }) : fallbackElement))), null);
1085 }
1086 function DataRoutes(_ref2) {
1087 let {
1088 routes,
1089 future,
1090 state
1091 } = _ref2;
1092 return useRoutesImpl(routes, undefined, state, future);
1093 }
1094 /**
1095 * A `<Router>` that stores all entries in memory.
1096 *
[0c6b92a]1097 * @see https://reactrouter.com/v6/router-components/memory-router
[d565449]1098 */
1099 function MemoryRouter(_ref3) {
1100 let {
1101 basename,
1102 children,
1103 initialEntries,
1104 initialIndex,
1105 future
1106 } = _ref3;
1107 let historyRef = React__namespace.useRef();
1108 if (historyRef.current == null) {
1109 historyRef.current = router.createMemoryHistory({
1110 initialEntries,
1111 initialIndex,
1112 v5Compat: true
1113 });
1114 }
1115 let history = historyRef.current;
1116 let [state, setStateImpl] = React__namespace.useState({
1117 action: history.action,
1118 location: history.location
1119 });
1120 let {
1121 v7_startTransition
1122 } = future || {};
1123 let setState = React__namespace.useCallback(newState => {
1124 v7_startTransition && startTransitionImpl ? startTransitionImpl(() => setStateImpl(newState)) : setStateImpl(newState);
1125 }, [setStateImpl, v7_startTransition]);
1126 React__namespace.useLayoutEffect(() => history.listen(setState), [history, setState]);
[0c6b92a]1127 React__namespace.useEffect(() => logV6DeprecationWarnings(future), [future]);
[d565449]1128 return /*#__PURE__*/React__namespace.createElement(Router, {
1129 basename: basename,
1130 children: children,
1131 location: state.location,
1132 navigationType: state.action,
1133 navigator: history,
1134 future: future
1135 });
1136 }
1137 /**
1138 * Changes the current location.
1139 *
1140 * Note: This API is mostly useful in React.Component subclasses that are not
1141 * able to use hooks. In functional components, we recommend you use the
1142 * `useNavigate` hook instead.
1143 *
[0c6b92a]1144 * @see https://reactrouter.com/v6/components/navigate
[d565449]1145 */
1146 function Navigate(_ref4) {
1147 let {
1148 to,
1149 replace,
1150 state,
1151 relative
1152 } = _ref4;
1153 !useInRouterContext() ? router.UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of
1154 // the router loaded. We can help them understand how to avoid that.
1155 "<Navigate> may be used only in the context of a <Router> component.") : void 0;
1156 let {
1157 future,
1158 static: isStatic
1159 } = React__namespace.useContext(NavigationContext);
1160 router.UNSAFE_warning(!isStatic, "<Navigate> must not be used on the initial render in a <StaticRouter>. " + "This is a no-op, but you should modify your code so the <Navigate> is " + "only ever rendered in response to some user interaction or state change.") ;
1161 let {
1162 matches
1163 } = React__namespace.useContext(RouteContext);
1164 let {
1165 pathname: locationPathname
1166 } = useLocation();
1167 let navigate = useNavigate();
1168
1169 // Resolve the path outside of the effect so that when effects run twice in
1170 // StrictMode they navigate to the same place
1171 let path = router.resolveTo(to, router.UNSAFE_getResolveToMatches(matches, future.v7_relativeSplatPath), locationPathname, relative === "path");
1172 let jsonPath = JSON.stringify(path);
1173 React__namespace.useEffect(() => navigate(JSON.parse(jsonPath), {
1174 replace,
1175 state,
1176 relative
1177 }), [navigate, jsonPath, relative, replace, state]);
1178 return null;
1179 }
1180 /**
1181 * Renders the child route's element, if there is one.
1182 *
[0c6b92a]1183 * @see https://reactrouter.com/v6/components/outlet
[d565449]1184 */
1185 function Outlet(props) {
1186 return useOutlet(props.context);
1187 }
1188 /**
1189 * Declares an element that should be rendered at a certain URL path.
1190 *
[0c6b92a]1191 * @see https://reactrouter.com/v6/components/route
[d565449]1192 */
1193 function Route(_props) {
1194 router.UNSAFE_invariant(false, "A <Route> is only ever to be used as the child of <Routes> element, " + "never rendered directly. Please wrap your <Route> in a <Routes>.") ;
1195 }
1196 /**
1197 * Provides location context for the rest of the app.
1198 *
1199 * Note: You usually won't render a `<Router>` directly. Instead, you'll render a
1200 * router that is more specific to your environment such as a `<BrowserRouter>`
1201 * in web browsers or a `<StaticRouter>` for server rendering.
1202 *
[0c6b92a]1203 * @see https://reactrouter.com/v6/router-components/router
[d565449]1204 */
1205 function Router(_ref5) {
1206 let {
1207 basename: basenameProp = "/",
1208 children = null,
1209 location: locationProp,
1210 navigationType = router.Action.Pop,
1211 navigator,
1212 static: staticProp = false,
1213 future
1214 } = _ref5;
1215 !!useInRouterContext() ? router.UNSAFE_invariant(false, "You cannot render a <Router> inside another <Router>." + " You should never have more than one in your app.") : void 0;
1216
1217 // Preserve trailing slashes on basename, so we can let the user control
1218 // the enforcement of trailing slashes throughout the app
1219 let basename = basenameProp.replace(/^\/*/, "/");
1220 let navigationContext = React__namespace.useMemo(() => ({
1221 basename,
1222 navigator,
1223 static: staticProp,
1224 future: _extends({
1225 v7_relativeSplatPath: false
1226 }, future)
1227 }), [basename, future, navigator, staticProp]);
1228 if (typeof locationProp === "string") {
1229 locationProp = router.parsePath(locationProp);
1230 }
1231 let {
1232 pathname = "/",
1233 search = "",
1234 hash = "",
1235 state = null,
1236 key = "default"
1237 } = locationProp;
1238 let locationContext = React__namespace.useMemo(() => {
1239 let trailingPathname = router.stripBasename(pathname, basename);
1240 if (trailingPathname == null) {
1241 return null;
1242 }
1243 return {
1244 location: {
1245 pathname: trailingPathname,
1246 search,
1247 hash,
1248 state,
1249 key
1250 },
1251 navigationType
1252 };
1253 }, [basename, pathname, search, hash, state, key, navigationType]);
1254 router.UNSAFE_warning(locationContext != null, "<Router basename=\"" + basename + "\"> is not able to match the URL " + ("\"" + pathname + search + hash + "\" because it does not start with the ") + "basename, so the <Router> won't render anything.") ;
1255 if (locationContext == null) {
1256 return null;
1257 }
1258 return /*#__PURE__*/React__namespace.createElement(NavigationContext.Provider, {
1259 value: navigationContext
1260 }, /*#__PURE__*/React__namespace.createElement(LocationContext.Provider, {
1261 children: children,
1262 value: locationContext
1263 }));
1264 }
1265 /**
1266 * A container for a nested tree of `<Route>` elements that renders the branch
1267 * that best matches the current location.
1268 *
[0c6b92a]1269 * @see https://reactrouter.com/v6/components/routes
[d565449]1270 */
1271 function Routes(_ref6) {
1272 let {
1273 children,
1274 location
1275 } = _ref6;
1276 return useRoutes(createRoutesFromChildren(children), location);
1277 }
1278 /**
1279 * Component to use for rendering lazily loaded data from returning defer()
1280 * in a loader function
1281 */
1282 function Await(_ref7) {
1283 let {
1284 children,
1285 errorElement,
1286 resolve
1287 } = _ref7;
1288 return /*#__PURE__*/React__namespace.createElement(AwaitErrorBoundary, {
1289 resolve: resolve,
1290 errorElement: errorElement
1291 }, /*#__PURE__*/React__namespace.createElement(ResolveAwait, null, children));
1292 }
1293 var AwaitRenderStatus = /*#__PURE__*/function (AwaitRenderStatus) {
1294 AwaitRenderStatus[AwaitRenderStatus["pending"] = 0] = "pending";
1295 AwaitRenderStatus[AwaitRenderStatus["success"] = 1] = "success";
1296 AwaitRenderStatus[AwaitRenderStatus["error"] = 2] = "error";
1297 return AwaitRenderStatus;
1298 }(AwaitRenderStatus || {});
1299 const neverSettledPromise = new Promise(() => {});
1300 class AwaitErrorBoundary extends React__namespace.Component {
1301 constructor(props) {
1302 super(props);
1303 this.state = {
1304 error: null
1305 };
1306 }
1307 static getDerivedStateFromError(error) {
1308 return {
1309 error
1310 };
1311 }
1312 componentDidCatch(error, errorInfo) {
1313 console.error("<Await> caught the following error during render", error, errorInfo);
1314 }
1315 render() {
1316 let {
1317 children,
1318 errorElement,
1319 resolve
1320 } = this.props;
1321 let promise = null;
1322 let status = AwaitRenderStatus.pending;
1323 if (!(resolve instanceof Promise)) {
1324 // Didn't get a promise - provide as a resolved promise
1325 status = AwaitRenderStatus.success;
1326 promise = Promise.resolve();
1327 Object.defineProperty(promise, "_tracked", {
1328 get: () => true
1329 });
1330 Object.defineProperty(promise, "_data", {
1331 get: () => resolve
1332 });
1333 } else if (this.state.error) {
1334 // Caught a render error, provide it as a rejected promise
1335 status = AwaitRenderStatus.error;
1336 let renderError = this.state.error;
1337 promise = Promise.reject().catch(() => {}); // Avoid unhandled rejection warnings
1338 Object.defineProperty(promise, "_tracked", {
1339 get: () => true
1340 });
1341 Object.defineProperty(promise, "_error", {
1342 get: () => renderError
1343 });
1344 } else if (resolve._tracked) {
1345 // Already tracked promise - check contents
1346 promise = resolve;
1347 status = "_error" in promise ? AwaitRenderStatus.error : "_data" in promise ? AwaitRenderStatus.success : AwaitRenderStatus.pending;
1348 } else {
1349 // Raw (untracked) promise - track it
1350 status = AwaitRenderStatus.pending;
1351 Object.defineProperty(resolve, "_tracked", {
1352 get: () => true
1353 });
1354 promise = resolve.then(data => Object.defineProperty(resolve, "_data", {
1355 get: () => data
1356 }), error => Object.defineProperty(resolve, "_error", {
1357 get: () => error
1358 }));
1359 }
1360 if (status === AwaitRenderStatus.error && promise._error instanceof router.AbortedDeferredError) {
1361 // Freeze the UI by throwing a never resolved promise
1362 throw neverSettledPromise;
1363 }
1364 if (status === AwaitRenderStatus.error && !errorElement) {
1365 // No errorElement, throw to the nearest route-level error boundary
1366 throw promise._error;
1367 }
1368 if (status === AwaitRenderStatus.error) {
1369 // Render via our errorElement
1370 return /*#__PURE__*/React__namespace.createElement(AwaitContext.Provider, {
1371 value: promise,
1372 children: errorElement
1373 });
1374 }
1375 if (status === AwaitRenderStatus.success) {
1376 // Render children with resolved value
1377 return /*#__PURE__*/React__namespace.createElement(AwaitContext.Provider, {
1378 value: promise,
1379 children: children
1380 });
1381 }
1382
1383 // Throw to the suspense boundary
1384 throw promise;
1385 }
1386 }
1387
1388 /**
1389 * @private
1390 * Indirection to leverage useAsyncValue for a render-prop API on `<Await>`
1391 */
1392 function ResolveAwait(_ref8) {
1393 let {
1394 children
1395 } = _ref8;
1396 let data = useAsyncValue();
1397 let toRender = typeof children === "function" ? children(data) : children;
1398 return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, toRender);
1399 }
1400
1401 ///////////////////////////////////////////////////////////////////////////////
1402 // UTILS
1403 ///////////////////////////////////////////////////////////////////////////////
1404
1405 /**
1406 * Creates a route config from a React "children" object, which is usually
1407 * either a `<Route>` element or an array of them. Used internally by
1408 * `<Routes>` to create a route config from its children.
1409 *
[0c6b92a]1410 * @see https://reactrouter.com/v6/utils/create-routes-from-children
[d565449]1411 */
1412 function createRoutesFromChildren(children, parentPath) {
1413 if (parentPath === void 0) {
1414 parentPath = [];
1415 }
1416 let routes = [];
1417 React__namespace.Children.forEach(children, (element, index) => {
1418 if (! /*#__PURE__*/React__namespace.isValidElement(element)) {
1419 // Ignore non-elements. This allows people to more easily inline
1420 // conditionals in their route config.
1421 return;
1422 }
1423 let treePath = [...parentPath, index];
1424 if (element.type === React__namespace.Fragment) {
1425 // Transparently support React.Fragment and its children.
1426 routes.push.apply(routes, createRoutesFromChildren(element.props.children, treePath));
1427 return;
1428 }
1429 !(element.type === Route) ? router.UNSAFE_invariant(false, "[" + (typeof element.type === "string" ? element.type : element.type.name) + "] is not a <Route> component. All component children of <Routes> must be a <Route> or <React.Fragment>") : void 0;
1430 !(!element.props.index || !element.props.children) ? router.UNSAFE_invariant(false, "An index route cannot have child routes.") : void 0;
1431 let route = {
1432 id: element.props.id || treePath.join("-"),
1433 caseSensitive: element.props.caseSensitive,
1434 element: element.props.element,
1435 Component: element.props.Component,
1436 index: element.props.index,
1437 path: element.props.path,
1438 loader: element.props.loader,
1439 action: element.props.action,
1440 errorElement: element.props.errorElement,
1441 ErrorBoundary: element.props.ErrorBoundary,
1442 hasErrorBoundary: element.props.ErrorBoundary != null || element.props.errorElement != null,
1443 shouldRevalidate: element.props.shouldRevalidate,
1444 handle: element.props.handle,
1445 lazy: element.props.lazy
1446 };
1447 if (element.props.children) {
1448 route.children = createRoutesFromChildren(element.props.children, treePath);
1449 }
1450 routes.push(route);
1451 });
1452 return routes;
1453 }
1454
1455 /**
1456 * Renders the result of `matchRoutes()` into a React element.
1457 */
1458 function renderMatches(matches) {
1459 return _renderMatches(matches);
1460 }
1461
1462 function mapRouteProperties(route) {
1463 let updates = {
1464 // Note: this check also occurs in createRoutesFromChildren so update
1465 // there if you change this -- please and thank you!
1466 hasErrorBoundary: route.ErrorBoundary != null || route.errorElement != null
1467 };
1468 if (route.Component) {
1469 {
1470 if (route.element) {
1471 router.UNSAFE_warning(false, "You should not include both `Component` and `element` on your route - " + "`Component` will be used.") ;
1472 }
1473 }
1474 Object.assign(updates, {
1475 element: /*#__PURE__*/React__namespace.createElement(route.Component),
1476 Component: undefined
1477 });
1478 }
1479 if (route.HydrateFallback) {
1480 {
1481 if (route.hydrateFallbackElement) {
1482 router.UNSAFE_warning(false, "You should not include both `HydrateFallback` and `hydrateFallbackElement` on your route - " + "`HydrateFallback` will be used.") ;
1483 }
1484 }
1485 Object.assign(updates, {
1486 hydrateFallbackElement: /*#__PURE__*/React__namespace.createElement(route.HydrateFallback),
1487 HydrateFallback: undefined
1488 });
1489 }
1490 if (route.ErrorBoundary) {
1491 {
1492 if (route.errorElement) {
1493 router.UNSAFE_warning(false, "You should not include both `ErrorBoundary` and `errorElement` on your route - " + "`ErrorBoundary` will be used.") ;
1494 }
1495 }
1496 Object.assign(updates, {
1497 errorElement: /*#__PURE__*/React__namespace.createElement(route.ErrorBoundary),
1498 ErrorBoundary: undefined
1499 });
1500 }
1501 return updates;
1502 }
1503 function createMemoryRouter(routes, opts) {
1504 return router.createRouter({
1505 basename: opts == null ? void 0 : opts.basename,
1506 future: _extends({}, opts == null ? void 0 : opts.future, {
1507 v7_prependBasename: true
1508 }),
1509 history: router.createMemoryHistory({
1510 initialEntries: opts == null ? void 0 : opts.initialEntries,
1511 initialIndex: opts == null ? void 0 : opts.initialIndex
1512 }),
1513 hydrationData: opts == null ? void 0 : opts.hydrationData,
1514 routes,
1515 mapRouteProperties,
[0c6b92a]1516 dataStrategy: opts == null ? void 0 : opts.dataStrategy,
1517 patchRoutesOnNavigation: opts == null ? void 0 : opts.patchRoutesOnNavigation
[d565449]1518 }).initialize();
1519 }
1520
1521 Object.defineProperty(exports, 'AbortedDeferredError', {
1522 enumerable: true,
1523 get: function () { return router.AbortedDeferredError; }
1524 });
1525 Object.defineProperty(exports, 'NavigationType', {
1526 enumerable: true,
1527 get: function () { return router.Action; }
1528 });
1529 Object.defineProperty(exports, 'createPath', {
1530 enumerable: true,
1531 get: function () { return router.createPath; }
1532 });
1533 Object.defineProperty(exports, 'defer', {
1534 enumerable: true,
1535 get: function () { return router.defer; }
1536 });
1537 Object.defineProperty(exports, 'generatePath', {
1538 enumerable: true,
1539 get: function () { return router.generatePath; }
1540 });
1541 Object.defineProperty(exports, 'isRouteErrorResponse', {
1542 enumerable: true,
1543 get: function () { return router.isRouteErrorResponse; }
1544 });
1545 Object.defineProperty(exports, 'json', {
1546 enumerable: true,
1547 get: function () { return router.json; }
1548 });
1549 Object.defineProperty(exports, 'matchPath', {
1550 enumerable: true,
1551 get: function () { return router.matchPath; }
1552 });
1553 Object.defineProperty(exports, 'matchRoutes', {
1554 enumerable: true,
1555 get: function () { return router.matchRoutes; }
1556 });
1557 Object.defineProperty(exports, 'parsePath', {
1558 enumerable: true,
1559 get: function () { return router.parsePath; }
1560 });
1561 Object.defineProperty(exports, 'redirect', {
1562 enumerable: true,
1563 get: function () { return router.redirect; }
1564 });
1565 Object.defineProperty(exports, 'redirectDocument', {
1566 enumerable: true,
1567 get: function () { return router.redirectDocument; }
1568 });
1569 Object.defineProperty(exports, 'replace', {
1570 enumerable: true,
1571 get: function () { return router.replace; }
1572 });
1573 Object.defineProperty(exports, 'resolvePath', {
1574 enumerable: true,
1575 get: function () { return router.resolvePath; }
1576 });
1577 exports.Await = Await;
1578 exports.MemoryRouter = MemoryRouter;
1579 exports.Navigate = Navigate;
1580 exports.Outlet = Outlet;
1581 exports.Route = Route;
1582 exports.Router = Router;
1583 exports.RouterProvider = RouterProvider;
1584 exports.Routes = Routes;
1585 exports.UNSAFE_DataRouterContext = DataRouterContext;
1586 exports.UNSAFE_DataRouterStateContext = DataRouterStateContext;
1587 exports.UNSAFE_LocationContext = LocationContext;
1588 exports.UNSAFE_NavigationContext = NavigationContext;
1589 exports.UNSAFE_RouteContext = RouteContext;
[0c6b92a]1590 exports.UNSAFE_logV6DeprecationWarnings = logV6DeprecationWarnings;
[d565449]1591 exports.UNSAFE_mapRouteProperties = mapRouteProperties;
1592 exports.UNSAFE_useRouteId = useRouteId;
1593 exports.UNSAFE_useRoutesImpl = useRoutesImpl;
1594 exports.createMemoryRouter = createMemoryRouter;
1595 exports.createRoutesFromChildren = createRoutesFromChildren;
1596 exports.createRoutesFromElements = createRoutesFromChildren;
1597 exports.renderMatches = renderMatches;
1598 exports.useActionData = useActionData;
1599 exports.useAsyncError = useAsyncError;
1600 exports.useAsyncValue = useAsyncValue;
1601 exports.useBlocker = useBlocker;
1602 exports.useHref = useHref;
1603 exports.useInRouterContext = useInRouterContext;
1604 exports.useLoaderData = useLoaderData;
1605 exports.useLocation = useLocation;
1606 exports.useMatch = useMatch;
1607 exports.useMatches = useMatches;
1608 exports.useNavigate = useNavigate;
1609 exports.useNavigation = useNavigation;
1610 exports.useNavigationType = useNavigationType;
1611 exports.useOutlet = useOutlet;
1612 exports.useOutletContext = useOutletContext;
1613 exports.useParams = useParams;
1614 exports.useResolvedPath = useResolvedPath;
1615 exports.useRevalidator = useRevalidator;
1616 exports.useRouteError = useRouteError;
1617 exports.useRouteLoaderData = useRouteLoaderData;
1618 exports.useRoutes = useRoutes;
1619
1620 Object.defineProperty(exports, '__esModule', { value: true });
1621
1622}));
1623//# sourceMappingURL=react-router.development.js.map
Note: See TracBrowser for help on using the repository browser.