You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

25 lines
180 KiB
JavaScript

"use strict";
/*
* ATTENTION: An "eval-source-map" devtool has been used.
* This devtool is neither made for production nor for readable output files.
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
* or disable the default devtool with "devtool: false".
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
*/
exports.id = "vendor-chunks/react-router";
exports.ids = ["vendor-chunks/react-router"];
exports.modules = {
/***/ "(ssr)/./node_modules/react-router/dist/index.js":
/*!*************************************************!*\
!*** ./node_modules/react-router/dist/index.js ***!
\*************************************************/
/***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ AbortedDeferredError: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.AbortedDeferredError),\n/* harmony export */ Await: () => (/* binding */ Await),\n/* harmony export */ MemoryRouter: () => (/* binding */ MemoryRouter),\n/* harmony export */ Navigate: () => (/* binding */ Navigate),\n/* harmony export */ NavigationType: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.Action),\n/* harmony export */ Outlet: () => (/* binding */ Outlet),\n/* harmony export */ Route: () => (/* binding */ Route),\n/* harmony export */ Router: () => (/* binding */ Router),\n/* harmony export */ RouterProvider: () => (/* binding */ RouterProvider),\n/* harmony export */ Routes: () => (/* binding */ Routes),\n/* harmony export */ UNSAFE_DataRouterContext: () => (/* binding */ DataRouterContext),\n/* harmony export */ UNSAFE_DataRouterStateContext: () => (/* binding */ DataRouterStateContext),\n/* harmony export */ UNSAFE_LocationContext: () => (/* binding */ LocationContext),\n/* harmony export */ UNSAFE_NavigationContext: () => (/* binding */ NavigationContext),\n/* harmony export */ UNSAFE_RouteContext: () => (/* binding */ RouteContext),\n/* harmony export */ UNSAFE_mapRouteProperties: () => (/* binding */ mapRouteProperties),\n/* harmony export */ UNSAFE_useRouteId: () => (/* binding */ useRouteId),\n/* harmony export */ UNSAFE_useRoutesImpl: () => (/* binding */ useRoutesImpl),\n/* harmony export */ createMemoryRouter: () => (/* binding */ createMemoryRouter),\n/* harmony export */ createPath: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.createPath),\n/* harmony export */ createRoutesFromChildren: () => (/* binding */ createRoutesFromChildren),\n/* harmony export */ createRoutesFromElements: () => (/* binding */ createRoutesFromChildren),\n/* harmony export */ defer: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.defer),\n/* harmony export */ generatePath: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.generatePath),\n/* harmony export */ isRouteErrorResponse: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.isRouteErrorResponse),\n/* harmony export */ json: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.json),\n/* harmony export */ matchPath: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.matchPath),\n/* harmony export */ matchRoutes: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.matchRoutes),\n/* harmony export */ parsePath: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.parsePath),\n/* harmony export */ redirect: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.redirect),\n/* harmony export */ redirectDocument: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.redirectDocument),\n/* harmony export */ renderMatches: () => (/* binding */ renderMatches),\n/* harmony export */ resolvePath: () => (/* reexport safe */ _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.resolvePath),\n/* harmony export */ unstable_useBlocker: () => (/* binding */ useBlocker),\n/* harmony export */ useActionData: () => (/* binding */ useActionData),\n/* harmony export */ useAsyncError: () => (/* binding */ useAsyncError),\n/* harmony export */ useAsyncValue: () => (/* binding */ useAsyncValue),\n/* harmony export */ useHref: () => (/* binding */ useHref),\n/* harmony export */ useInRouterContext: () => (/* binding */ useInRouterContext),\n/* harmony export */ useLoaderData: () => (/* binding */ useLoaderData),\n/* harmony export */ useLocation: () => (/* binding */ useLocation),\n/* harmony export */ useMatch: () => (/* binding */ useMatch),\n/* harmony export */ useMatches: () => (/* binding */ useMatches),\n/* harmony export */ useNavigate: () => (/* binding */ useNavigate),\n/* harmony export */ useNavigation: () => (/* binding */ useNavigation),\n/* harmony export */ useNavigationType: () => (/* binding */ useNavigationType),\n/* harmony export */ useOutlet: () => (/* binding */ useOutlet),\n/* harmony export */ useOutletContext: () => (/* binding */ useOutletContext),\n/* harmony export */ useParams: () => (/* binding */ useParams),\n/* harmony export */ useResolvedPath: () => (/* binding */ useResolvedPath),\n/* harmony export */ useRevalidator: () => (/* binding */ useRevalidator),\n/* harmony export */ useRouteError: () => (/* binding */ useRouteError),\n/* harmony export */ useRouteLoaderData: () => (/* binding */ useRouteLoaderData),\n/* harmony export */ useRoutes: () => (/* binding */ useRoutes)\n/* harmony export */ });\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! react */ \"(ssr)/./node_modules/next/dist/server/future/route-modules/app-page/vendored/ssr/react.js\");\n/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _remix_run_router__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @remix-run/router */ \"(ssr)/./node_modules/@remix-run/router/dist/router.js\");\n/**\n * React Router v6.15.0\n *\n * Copyright (c) Remix Software Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.md file in the root directory of this source tree.\n *\n * @license MIT\n */ \n\n\nfunction _extends() {\n _extends = Object.assign ? Object.assign.bind() : function(target) {\n for(var i = 1; i < arguments.length; i++){\n var source = arguments[i];\n for(var key in source){\n if (Object.prototype.hasOwnProperty.call(source, key)) {\n target[key] = source[key];\n }\n }\n }\n return target;\n };\n return _extends.apply(this, arguments);\n}\n// Create react-specific types from the agnostic types in @remix-run/router to\n// export from react-router\nconst DataRouterContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext(null);\nif (true) {\n DataRouterContext.displayName = \"DataRouter\";\n}\nconst DataRouterStateContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext(null);\nif (true) {\n DataRouterStateContext.displayName = \"DataRouterState\";\n}\nconst AwaitContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext(null);\nif (true) {\n AwaitContext.displayName = \"Await\";\n}\n/**\n * A Navigator is a \"location changer\"; it's how you get to different locations.\n *\n * Every history instance conforms to the Navigator interface, but the\n * distinction is useful primarily when it comes to the low-level <Router> API\n * where both the location and a navigator must be provided separately in order\n * to avoid \"tearing\" that may occur in a suspense-enabled app if the action\n * and/or location were to be read directly from the history instance.\n */ const NavigationContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext(null);\nif (true) {\n NavigationContext.displayName = \"Navigation\";\n}\nconst LocationContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext(null);\nif (true) {\n LocationContext.displayName = \"Location\";\n}\nconst RouteContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext({\n outlet: null,\n matches: [],\n isDataRoute: false\n});\nif (true) {\n RouteContext.displayName = \"Route\";\n}\nconst RouteErrorContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext(null);\nif (true) {\n RouteErrorContext.displayName = \"RouteError\";\n}\n/**\n * Returns the full href for the given \"to\" value. This is useful for building\n * custom links that are also accessible and preserve right-click behavior.\n *\n * @see https://reactrouter.com/hooks/use-href\n */ function useHref(to, _temp) {\n let { relative } = _temp === void 0 ? {} : _temp;\n !useInRouterContext() ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, // router loaded. We can help them understand how to avoid that.\n \"useHref() may be used only in the context of a <Router> component.\") : 0 : void 0;\n let { basename, navigator } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(NavigationContext);\n let { hash, pathname, search } = useResolvedPath(to, {\n relative\n });\n let joinedPathname = pathname;\n // If we're operating within a basename, prepend it to the pathname prior\n // to creating the href. If this is a root navigation, then just use the raw\n // basename which allows the basename to have full control over the presence\n // of a trailing slash on root links\n if (basename !== \"/\") {\n joinedPathname = pathname === \"/\" ? basename : (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.joinPaths)([\n basename,\n pathname\n ]);\n }\n return navigator.createHref({\n pathname: joinedPathname,\n search,\n hash\n });\n}\n/**\n * Returns true if this component is a descendant of a <Router>.\n *\n * @see https://reactrouter.com/hooks/use-in-router-context\n */ function useInRouterContext() {\n return react__WEBPACK_IMPORTED_MODULE_0__.useContext(LocationContext) != null;\n}\n/**\n * Returns the current location object, which represents the current URL in web\n * browsers.\n *\n * Note: If you're using this it may mean you're doing some of your own\n * \"routing\" in your app, and we'd like to know what your use case is. We may\n * be able to provide something higher-level to better suit your needs.\n *\n * @see https://reactrouter.com/hooks/use-location\n */ function useLocation() {\n !useInRouterContext() ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, // router loaded. We can help them understand how to avoid that.\n \"useLocation() may be used only in the context of a <Router> component.\") : 0 : void 0;\n return react__WEBPACK_IMPORTED_MODULE_0__.useContext(LocationContext).location;\n}\n/**\n * Returns the current navigation action which describes how the router came to\n * the current location, either by a pop, push, or replace on the history stack.\n *\n * @see https://reactrouter.com/hooks/use-navigation-type\n */ function useNavigationType() {\n return react__WEBPACK_IMPORTED_MODULE_0__.useContext(LocationContext).navigationType;\n}\n/**\n * Returns a PathMatch object if the given pattern matches the current URL.\n * This is useful for components that need to know \"active\" state, e.g.\n * <NavLink>.\n *\n * @see https://reactrouter.com/hooks/use-match\n */ function useMatch(pattern) {\n !useInRouterContext() ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, // router loaded. We can help them understand how to avoid that.\n \"useMatch() may be used only in the context of a <Router> component.\") : 0 : void 0;\n let { pathname } = useLocation();\n return react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>(0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.matchPath)(pattern, pathname), [\n pathname,\n pattern\n ]);\n}\n/**\n * The interface for the navigate() function returned from useNavigate().\n */ const navigateEffectWarning = \"You should call navigate() in a React.useEffect(), not when \" + \"your component is first rendered.\";\n// Mute warnings for calls to useNavigate in SSR environments\nfunction useIsomorphicLayoutEffect(cb) {\n let isStatic = react__WEBPACK_IMPORTED_MODULE_0__.useContext(NavigationContext).static;\n if (!isStatic) {\n // We should be able to get rid of this once react 18.3 is released\n // See: https://github.com/facebook/react/pull/26395\n // eslint-disable-next-line react-hooks/rules-of-hooks\n react__WEBPACK_IMPORTED_MODULE_0__.useLayoutEffect(cb);\n }\n}\n/**\n * Returns an imperative method for changing the location. Used by <Link>s, but\n * may also be used by other elements to change the location.\n *\n * @see https://reactrouter.com/hooks/use-navigate\n */ function useNavigate() {\n let { isDataRoute } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n // Conditional usage is OK here because the usage of a data router is static\n // eslint-disable-next-line react-hooks/rules-of-hooks\n return isDataRoute ? useNavigateStable() : useNavigateUnstable();\n}\nfunction useNavigateUnstable() {\n !useInRouterContext() ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, // router loaded. We can help them understand how to avoid that.\n \"useNavigate() may be used only in the context of a <Router> component.\") : 0 : void 0;\n let dataRouterContext = react__WEBPACK_IMPORTED_MODULE_0__.useContext(DataRouterContext);\n let { basename, navigator } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(NavigationContext);\n let { matches } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let routePathnamesJson = JSON.stringify((0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_getPathContributingMatches)(matches).map((match)=>match.pathnameBase));\n let activeRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(false);\n useIsomorphicLayoutEffect(()=>{\n activeRef.current = true;\n });\n let navigate = react__WEBPACK_IMPORTED_MODULE_0__.useCallback(function(to, options) {\n if (options === void 0) {\n options = {};\n }\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(activeRef.current, navigateEffectWarning) : 0;\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our history listener yet\n if (!activeRef.current) return;\n if (typeof to === \"number\") {\n navigator.go(to);\n return;\n }\n let path = (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.resolveTo)(to, JSON.parse(routePathnamesJson), locationPathname, options.relative === \"path\");\n // If we're operating within a basename, prepend it to the pathname prior\n // to handing off to history (but only if we're not in a data router,\n // otherwise it'll prepend the basename inside of the router).\n // If this is a root navigation, then we navigate to the raw basename\n // which allows the basename to have full control over the presence of a\n // trailing slash on root links\n if (dataRouterContext == null && basename !== \"/\") {\n path.pathname = path.pathname === \"/\" ? basename : (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.joinPaths)([\n basename,\n path.pathname\n ]);\n }\n (!!options.replace ? navigator.replace : navigator.push)(path, options.state, options);\n }, [\n basename,\n navigator,\n routePathnamesJson,\n locationPathname,\n dataRouterContext\n ]);\n return navigate;\n}\nconst OutletContext = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createContext(null);\n/**\n * Returns the context (if provided) for the child route at this level of the route\n * hierarchy.\n * @see https://reactrouter.com/hooks/use-outlet-context\n */ function useOutletContext() {\n return react__WEBPACK_IMPORTED_MODULE_0__.useContext(OutletContext);\n}\n/**\n * Returns the element for the child route at this level of the route\n * hierarchy. Used internally by <Outlet> to render child routes.\n *\n * @see https://reactrouter.com/hooks/use-outlet\n */ function useOutlet(context) {\n let outlet = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext).outlet;\n if (outlet) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(OutletContext.Provider, {\n value: context\n }, outlet);\n }\n return outlet;\n}\n/**\n * Returns an object of key/value pairs of the dynamic params from the current\n * URL that were matched by the route path.\n *\n * @see https://reactrouter.com/hooks/use-params\n */ function useParams() {\n let { matches } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n let routeMatch = matches[matches.length - 1];\n return routeMatch ? routeMatch.params : {};\n}\n/**\n * Resolves the pathname of the given `to` value against the current location.\n *\n * @see https://reactrouter.com/hooks/use-resolved-path\n */ function useResolvedPath(to, _temp2) {\n let { relative } = _temp2 === void 0 ? {} : _temp2;\n let { matches } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let routePathnamesJson = JSON.stringify((0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_getPathContributingMatches)(matches).map((match)=>match.pathnameBase));\n return react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>(0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.resolveTo)(to, JSON.parse(routePathnamesJson), locationPathname, relative === \"path\"), [\n to,\n routePathnamesJson,\n locationPathname,\n relative\n ]);\n}\n/**\n * Returns the element of the route that matched the current location, prepared\n * with the correct context to render the remainder of the route tree. Route\n * elements in the tree must render an <Outlet> to render their child route's\n * element.\n *\n * @see https://reactrouter.com/hooks/use-routes\n */ function useRoutes(routes, locationArg) {\n return useRoutesImpl(routes, locationArg);\n}\n// Internal implementation with accept optional param for RouterProvider usage\nfunction useRoutesImpl(routes, locationArg, dataRouterState) {\n !useInRouterContext() ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, // router loaded. We can help them understand how to avoid that.\n \"useRoutes() may be used only in the context of a <Router> component.\") : 0 : void 0;\n let { navigator } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(NavigationContext);\n let { matches: parentMatches } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n let routeMatch = parentMatches[parentMatches.length - 1];\n let parentParams = routeMatch ? routeMatch.params : {};\n let parentPathname = routeMatch ? routeMatch.pathname : \"/\";\n let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : \"/\";\n let parentRoute = routeMatch && routeMatch.route;\n if (true) {\n // You won't get a warning about 2 different <Routes> under a <Route>\n // without a trailing *, but this is a best-effort warning anyway since we\n // cannot even give the warning unless they land at the parent route.\n //\n // Example:\n //\n // <Routes>\n // {/* This route path MUST end with /* because otherwise\n // it will never match /blog/post/123 */}\n // <Route path=\"blog\" element={<Blog />} />\n // <Route path=\"blog/feed\" element={<BlogFeed />} />\n // </Routes>\n //\n // function Blog() {\n // return (\n // <Routes>\n // <Route path=\"post/:id\" element={<Post />} />\n // </Routes>\n // );\n // }\n let parentPath = parentRoute && parentRoute.path || \"\";\n 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 + \"/*\") + '\">.'));\n }\n let locationFromContext = useLocation();\n let location;\n if (locationArg) {\n var _parsedLocationArg$pa;\n let parsedLocationArg = typeof locationArg === \"string\" ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.parsePath)(locationArg) : locationArg;\n !(parentPathnameBase === \"/\" || ((_parsedLocationArg$pa = parsedLocationArg.pathname) == null ? void 0 : _parsedLocationArg$pa.startsWith(parentPathnameBase))) ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.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.')) : 0 : void 0;\n location = parsedLocationArg;\n } else {\n location = locationFromContext;\n }\n let pathname = location.pathname || \"/\";\n let remainingPathname = parentPathnameBase === \"/\" ? pathname : pathname.slice(parentPathnameBase.length) || \"/\";\n let matches = (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.matchRoutes)(routes, {\n pathname: remainingPathname\n });\n if (true) {\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(parentRoute || matches != null, 'No routes matched location \"' + location.pathname + location.search + location.hash + '\" ') : 0;\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(matches == null || matches[matches.length - 1].route.element !== undefined || matches[matches.length - 1].route.Component !== 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.') : 0;\n }\n let renderedMatches = _renderMatches(matches && matches.map((match)=>Object.assign({}, match, {\n params: Object.assign({}, parentParams, match.params),\n pathname: (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.joinPaths)([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation ? navigator.encodeLocation(match.pathname).pathname : match.pathname\n ]),\n pathnameBase: match.pathnameBase === \"/\" ? parentPathnameBase : (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.joinPaths)([\n parentPathnameBase,\n // Re-encode pathnames that were decoded inside matchRoutes\n navigator.encodeLocation ? navigator.encodeLocation(match.pathnameBase).pathname : match.pathnameBase\n ])\n })), parentMatches, dataRouterState);\n // When a user passes in a `locationArg`, the associated routes need to\n // be wrapped in a new `LocationContext.Provider` in order for `useLocation`\n // to use the scoped location instead of the global location.\n if (locationArg && renderedMatches) {\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(LocationContext.Provider, {\n value: {\n location: _extends({\n pathname: \"/\",\n search: \"\",\n hash: \"\",\n state: null,\n key: \"default\"\n }, location),\n navigationType: _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.Action.Pop\n }\n }, renderedMatches);\n }\n return renderedMatches;\n}\nfunction DefaultErrorComponent() {\n let error = useRouteError();\n let message = (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.isRouteErrorResponse)(error) ? error.status + \" \" + error.statusText : error instanceof Error ? error.message : JSON.stringify(error);\n let stack = error instanceof Error ? error.stack : null;\n let lightgrey = \"rgba(200,200,200, 0.5)\";\n let preStyles = {\n padding: \"0.5rem\",\n backgroundColor: lightgrey\n };\n let codeStyles = {\n padding: \"2px 4px\",\n backgroundColor: lightgrey\n };\n let devInfo = null;\n if (true) {\n console.error(\"Error handled by React Router default ErrorBoundary:\", error);\n devInfo = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"p\", null, \"\\uD83D\\uDCBF Hey developer \\uD83D\\uDC4B\"), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"p\", null, \"You can provide a way better UX than this when your app throws errors by providing your own \", /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"code\", {\n style: codeStyles\n }, \"ErrorBoundary\"), \" or\", \" \", /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"code\", {\n style: codeStyles\n }, \"errorElement\"), \" prop on your route.\"));\n }\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"h2\", null, \"Unexpected Application Error!\"), /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"h3\", {\n style: {\n fontStyle: \"italic\"\n }\n }, message), stack ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"pre\", {\n style: preStyles\n }, stack) : null, devInfo);\n}\nconst defaultErrorElement = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(DefaultErrorComponent, null);\nclass RenderErrorBoundary extends react__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor(props){\n super(props);\n this.state = {\n location: props.location,\n revalidation: props.revalidation,\n error: props.error\n };\n }\n static getDerivedStateFromError(error) {\n return {\n error: error\n };\n }\n static getDerivedStateFromProps(props, state) {\n // When we get into an error state, the user will likely click \"back\" to the\n // previous page that didn't have an error. Because this wraps the entire\n // application, that will have no effect--the error page continues to display.\n // This gives us a mechanism to recover from the error when the location changes.\n //\n // Whether we're in an error state or not, we update the location in state\n // so that when we are in an error state, it gets reset when a new location\n // comes in and the user recovers from the error.\n if (state.location !== props.location || state.revalidation !== \"idle\" && props.revalidation === \"idle\") {\n return {\n error: props.error,\n location: props.location,\n revalidation: props.revalidation\n };\n }\n // If we're not changing locations, preserve the location but still surface\n // any new errors that may come through. We retain the existing error, we do\n // this because the error provided from the app state may be cleared without\n // the location changing.\n return {\n error: props.error || state.error,\n location: state.location,\n revalidation: props.revalidation || state.revalidation\n };\n }\n componentDidCatch(error, errorInfo) {\n console.error(\"React Router caught the following error during render\", error, errorInfo);\n }\n render() {\n return this.state.error ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(RouteContext.Provider, {\n value: this.props.routeContext\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(RouteErrorContext.Provider, {\n value: this.state.error,\n children: this.props.component\n })) : this.props.children;\n }\n}\nfunction RenderedRoute(_ref) {\n let { routeContext, match, children } = _ref;\n let dataRouterContext = react__WEBPACK_IMPORTED_MODULE_0__.useContext(DataRouterContext);\n // Track how deep we got in our render pass to emulate SSR componentDidCatch\n // in a DataStaticRouter\n if (dataRouterContext && dataRouterContext.static && dataRouterContext.staticContext && (match.route.errorElement || match.route.ErrorBoundary)) {\n dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;\n }\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(RouteContext.Provider, {\n value: routeContext\n }, children);\n}\nfunction _renderMatches(matches, parentMatches, dataRouterState) {\n var _dataRouterState2;\n if (parentMatches === void 0) {\n parentMatches = [];\n }\n if (dataRouterState === void 0) {\n dataRouterState = null;\n }\n if (matches == null) {\n var _dataRouterState;\n if ((_dataRouterState = dataRouterState) != null && _dataRouterState.errors) {\n // Don't bail if we have data router errors so we can render them in the\n // boundary. Use the pre-matched (or shimmed) matches\n matches = dataRouterState.matches;\n } else {\n return null;\n }\n }\n let renderedMatches = matches;\n // If we have data errors, trim matches to the highest error boundary\n let errors = (_dataRouterState2 = dataRouterState) == null ? void 0 : _dataRouterState2.errors;\n if (errors != null) {\n let errorIndex = renderedMatches.findIndex((m)=>m.route.id && (errors == null ? void 0 : errors[m.route.id]));\n !(errorIndex >= 0) ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"Could not find a matching route for errors on route IDs: \" + Object.keys(errors).join(\",\")) : 0 : void 0;\n renderedMatches = renderedMatches.slice(0, Math.min(renderedMatches.length, errorIndex + 1));\n }\n return renderedMatches.reduceRight((outlet, match, index)=>{\n let error = match.route.id ? errors == null ? void 0 : errors[match.route.id] : null;\n // Only data routers handle errors\n let errorElement = null;\n if (dataRouterState) {\n errorElement = match.route.errorElement || defaultErrorElement;\n }\n let matches = parentMatches.concat(renderedMatches.slice(0, index + 1));\n let getChildren = ()=>{\n let children;\n if (error) {\n children = errorElement;\n } else if (match.route.Component) {\n // Note: This is a de-optimized path since React won't re-use the\n // ReactElement since it's identity changes with each new\n // React.createElement call. We keep this so folks can use\n // `<Route Component={...}>` in `<Routes>` but generally `Component`\n // usage is only advised in `RouterProvider` when we can convert it to\n // `element` ahead of time.\n children = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(match.route.Component, null);\n } else if (match.route.element) {\n children = match.route.element;\n } else {\n children = outlet;\n }\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(RenderedRoute, {\n match: match,\n routeContext: {\n outlet,\n matches,\n isDataRoute: dataRouterState != null\n },\n children: children\n });\n };\n // Only wrap in an error boundary within data router usages when we have an\n // ErrorBoundary/errorElement on this route. Otherwise let it bubble up to\n // an ancestor ErrorBoundary/errorElement\n return dataRouterState && (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(RenderErrorBoundary, {\n location: dataRouterState.location,\n revalidation: dataRouterState.revalidation,\n component: errorElement,\n error: error,\n children: getChildren(),\n routeContext: {\n outlet: null,\n matches,\n isDataRoute: true\n }\n }) : getChildren();\n }, null);\n}\nvar DataRouterHook = /*#__PURE__*/ function(DataRouterHook) {\n DataRouterHook[\"UseBlocker\"] = \"useBlocker\";\n DataRouterHook[\"UseRevalidator\"] = \"useRevalidator\";\n DataRouterHook[\"UseNavigateStable\"] = \"useNavigate\";\n return DataRouterHook;\n}(DataRouterHook || {});\nvar DataRouterStateHook = /*#__PURE__*/ function(DataRouterStateHook) {\n DataRouterStateHook[\"UseBlocker\"] = \"useBlocker\";\n DataRouterStateHook[\"UseLoaderData\"] = \"useLoaderData\";\n DataRouterStateHook[\"UseActionData\"] = \"useActionData\";\n DataRouterStateHook[\"UseRouteError\"] = \"useRouteError\";\n DataRouterStateHook[\"UseNavigation\"] = \"useNavigation\";\n DataRouterStateHook[\"UseRouteLoaderData\"] = \"useRouteLoaderData\";\n DataRouterStateHook[\"UseMatches\"] = \"useMatches\";\n DataRouterStateHook[\"UseRevalidator\"] = \"useRevalidator\";\n DataRouterStateHook[\"UseNavigateStable\"] = \"useNavigate\";\n DataRouterStateHook[\"UseRouteId\"] = \"useRouteId\";\n return DataRouterStateHook;\n}(DataRouterStateHook || {});\nfunction getDataRouterConsoleError(hookName) {\n return hookName + \" must be used within a data router. See https://reactrouter.com/routers/picking-a-router.\";\n}\nfunction useDataRouterContext(hookName) {\n let ctx = react__WEBPACK_IMPORTED_MODULE_0__.useContext(DataRouterContext);\n !ctx ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, getDataRouterConsoleError(hookName)) : 0 : void 0;\n return ctx;\n}\nfunction useDataRouterState(hookName) {\n let state = react__WEBPACK_IMPORTED_MODULE_0__.useContext(DataRouterStateContext);\n !state ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, getDataRouterConsoleError(hookName)) : 0 : void 0;\n return state;\n}\nfunction useRouteContext(hookName) {\n let route = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n !route ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, getDataRouterConsoleError(hookName)) : 0 : void 0;\n return route;\n}\n// Internal version with hookName-aware debugging\nfunction useCurrentRouteId(hookName) {\n let route = useRouteContext(hookName);\n let thisRoute = route.matches[route.matches.length - 1];\n !thisRoute.route.id ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, hookName + ' can only be used on routes that contain a unique \"id\"') : 0 : void 0;\n return thisRoute.route.id;\n}\n/**\n * Returns the ID for the nearest contextual route\n */ function useRouteId() {\n return useCurrentRouteId(DataRouterStateHook.UseRouteId);\n}\n/**\n * Returns the current navigation, defaulting to an \"idle\" navigation when\n * no navigation is in progress\n */ function useNavigation() {\n let state = useDataRouterState(DataRouterStateHook.UseNavigation);\n return state.navigation;\n}\n/**\n * Returns a revalidate function for manually triggering revalidation, as well\n * as the current state of any manual revalidations\n */ function useRevalidator() {\n let dataRouterContext = useDataRouterContext(DataRouterHook.UseRevalidator);\n let state = useDataRouterState(DataRouterStateHook.UseRevalidator);\n return react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>({\n revalidate: dataRouterContext.router.revalidate,\n state: state.revalidation\n }), [\n dataRouterContext.router.revalidate,\n state.revalidation\n ]);\n}\n/**\n * Returns the active route matches, useful for accessing loaderData for\n * parent/child routes or the route \"handle\" property\n */ function useMatches() {\n let { matches, loaderData } = useDataRouterState(DataRouterStateHook.UseMatches);\n return react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>matches.map((match)=>{\n let { pathname, params } = match;\n // Note: This structure matches that created by createUseMatchesMatch\n // in the @remix-run/router , so if you change this please also change\n // that :) Eventually we'll DRY this up\n return {\n id: match.route.id,\n pathname,\n params,\n data: loaderData[match.route.id],\n handle: match.route.handle\n };\n }), [\n matches,\n loaderData\n ]);\n}\n/**\n * Returns the loader data for the nearest ancestor Route loader\n */ function useLoaderData() {\n let state = useDataRouterState(DataRouterStateHook.UseLoaderData);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);\n if (state.errors && state.errors[routeId] != null) {\n console.error(\"You cannot `useLoaderData` in an errorElement (routeId: \" + routeId + \")\");\n return undefined;\n }\n return state.loaderData[routeId];\n}\n/**\n * Returns the loaderData for the given routeId\n */ function useRouteLoaderData(routeId) {\n let state = useDataRouterState(DataRouterStateHook.UseRouteLoaderData);\n return state.loaderData[routeId];\n}\n/**\n * Returns the action data for the nearest ancestor Route action\n */ function useActionData() {\n let state = useDataRouterState(DataRouterStateHook.UseActionData);\n let route = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n !route ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"useActionData must be used inside a RouteContext\") : 0 : void 0;\n return Object.values((state == null ? void 0 : state.actionData) || {})[0];\n}\n/**\n * Returns the nearest ancestor Route error, which could be a loader/action\n * error or a render error. This is intended to be called from your\n * ErrorBoundary/errorElement to display a proper error message.\n */ function useRouteError() {\n var _state$errors;\n let error = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteErrorContext);\n let state = useDataRouterState(DataRouterStateHook.UseRouteError);\n let routeId = useCurrentRouteId(DataRouterStateHook.UseRouteError);\n // If this was a render error, we put it in a RouteError context inside\n // of RenderErrorBoundary\n if (error) {\n return error;\n }\n // Otherwise look for errors from our data router state\n return (_state$errors = state.errors) == null ? void 0 : _state$errors[routeId];\n}\n/**\n * Returns the happy-path data from the nearest ancestor <Await /> value\n */ function useAsyncValue() {\n let value = react__WEBPACK_IMPORTED_MODULE_0__.useContext(AwaitContext);\n return value == null ? void 0 : value._data;\n}\n/**\n * Returns the error from the nearest ancestor <Await /> value\n */ function useAsyncError() {\n let value = react__WEBPACK_IMPORTED_MODULE_0__.useContext(AwaitContext);\n return value == null ? void 0 : value._error;\n}\nlet blockerId = 0;\n/**\n * Allow the application to block navigations within the SPA and present the\n * user a confirmation dialog to confirm the navigation. Mostly used to avoid\n * using half-filled form data. This does not handle hard-reloads or\n * cross-origin navigations.\n */ function useBlocker(shouldBlock) {\n let { router, basename } = useDataRouterContext(DataRouterHook.UseBlocker);\n let state = useDataRouterState(DataRouterStateHook.UseBlocker);\n let [blockerKey, setBlockerKey] = react__WEBPACK_IMPORTED_MODULE_0__.useState(\"\");\n let blockerFunction = react__WEBPACK_IMPORTED_MODULE_0__.useCallback((arg)=>{\n if (typeof shouldBlock !== \"function\") {\n return !!shouldBlock;\n }\n if (basename === \"/\") {\n return shouldBlock(arg);\n }\n // If they provided us a function and we've got an active basename, strip\n // it from the locations we expose to the user to match the behavior of\n // useLocation\n let { currentLocation, nextLocation, historyAction } = arg;\n return shouldBlock({\n currentLocation: _extends({}, currentLocation, {\n pathname: (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.stripBasename)(currentLocation.pathname, basename) || currentLocation.pathname\n }),\n nextLocation: _extends({}, nextLocation, {\n pathname: (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.stripBasename)(nextLocation.pathname, basename) || nextLocation.pathname\n }),\n historyAction\n });\n }, [\n basename,\n shouldBlock\n ]);\n // This effect is in charge of blocker key assignment and deletion (which is\n // tightly coupled to the key)\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n let key = String(++blockerId);\n setBlockerKey(key);\n return ()=>router.deleteBlocker(key);\n }, [\n router\n ]);\n // This effect handles assigning the blockerFunction. This is to handle\n // unstable blocker function identities, and happens only after the prior\n // effect so we don't get an orphaned blockerFunction in the router with a\n // key of \"\". Until then we just have the IDLE_BLOCKER.\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n if (blockerKey !== \"\") {\n router.getBlocker(blockerKey, blockerFunction);\n }\n }, [\n router,\n blockerKey,\n blockerFunction\n ]);\n // Prefer the blocker from `state` not `router.state` since DataRouterContext\n // is memoized so this ensures we update on blocker state updates\n return blockerKey && state.blockers.has(blockerKey) ? state.blockers.get(blockerKey) : _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.IDLE_BLOCKER;\n}\n/**\n * Stable version of useNavigate that is used when we are in the context of\n * a RouterProvider.\n */ function useNavigateStable() {\n let { router } = useDataRouterContext(DataRouterHook.UseNavigateStable);\n let id = useCurrentRouteId(DataRouterStateHook.UseNavigateStable);\n let activeRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(false);\n useIsomorphicLayoutEffect(()=>{\n activeRef.current = true;\n });\n let navigate = react__WEBPACK_IMPORTED_MODULE_0__.useCallback(function(to, options) {\n if (options === void 0) {\n options = {};\n }\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(activeRef.current, navigateEffectWarning) : 0;\n // Short circuit here since if this happens on first render the navigate\n // is useless because we haven't wired up our router subscriber yet\n if (!activeRef.current) return;\n if (typeof to === \"number\") {\n router.navigate(to);\n } else {\n router.navigate(to, _extends({\n fromRouteId: id\n }, options));\n }\n }, [\n router,\n id\n ]);\n return navigate;\n}\nconst alreadyWarned = {};\nfunction warningOnce(key, cond, message) {\n if (!cond && !alreadyWarned[key]) {\n alreadyWarned[key] = true;\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(false, message) : 0;\n }\n}\n/**\n Webpack + React 17 fails to compile on any of the following because webpack\n complains that `startTransition` doesn't exist in `React`:\n * import { startTransition } from \"react\"\n * import * as React from from \"react\";\n \"startTransition\" in React ? React.startTransition(() => setState()) : setState()\n * import * as React from from \"react\";\n \"startTransition\" in React ? React[\"startTransition\"](() => setState()) : setState()\n\n Moving it to a constant such as the following solves the Webpack/React 17 issue:\n * import * as React from from \"react\";\n const START_TRANSITION = \"startTransition\";\n START_TRANSITION in React ? React[START_TRANSITION](() => setState()) : setState()\n\n However, that introduces webpack/terser minification issues in production builds\n in React 18 where minification/obfuscation ends up removing the call of\n React.startTransition entirely from the first half of the ternary. Grabbing\n this exported reference once up front resolves that issue.\n\n See https://github.com/remix-run/react-router/issues/10579\n*/ const START_TRANSITION = \"startTransition\";\nconst startTransitionImpl = react__WEBPACK_IMPORTED_MODULE_0__[START_TRANSITION];\n/**\n * Given a Remix Router instance, render the appropriate UI\n */ function RouterProvider(_ref) {\n let { fallbackElement, router, future } = _ref;\n // Need to use a layout effect here so we are subscribed early enough to\n // pick up on any render-driven redirects/navigations (useEffect/<Navigate>)\n let [state, setStateImpl] = react__WEBPACK_IMPORTED_MODULE_0__.useState(router.state);\n let { v7_startTransition } = future || {};\n let setState = react__WEBPACK_IMPORTED_MODULE_0__.useCallback((newState)=>{\n v7_startTransition && startTransitionImpl ? startTransitionImpl(()=>setStateImpl(newState)) : setStateImpl(newState);\n }, [\n setStateImpl,\n v7_startTransition\n ]);\n react__WEBPACK_IMPORTED_MODULE_0__.useLayoutEffect(()=>router.subscribe(setState), [\n router,\n setState\n ]);\n let navigator = react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>{\n return {\n createHref: router.createHref,\n encodeLocation: router.encodeLocation,\n go: (n)=>router.navigate(n),\n push: (to, state, opts)=>router.navigate(to, {\n state,\n preventScrollReset: opts == null ? void 0 : opts.preventScrollReset\n }),\n replace: (to, state, opts)=>router.navigate(to, {\n replace: true,\n state,\n preventScrollReset: opts == null ? void 0 : opts.preventScrollReset\n })\n };\n }, [\n router\n ]);\n let basename = router.basename || \"/\";\n let dataRouterContext = react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>({\n router,\n navigator,\n static: false,\n basename\n }), [\n router,\n navigator,\n basename\n ]);\n // The fragment and {null} here are important! We need them to keep React 18's\n // useId happy when we are server-rendering since we may have a <script> here\n // containing the hydrated server-side staticContext (from StaticRouterProvider).\n // useId relies on the component tree structure to generate deterministic id's\n // so we need to ensure it remains the same on the client even though\n // we don't need the <script> tag\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(DataRouterContext.Provider, {\n value: dataRouterContext\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(DataRouterStateContext.Provider, {\n value: state\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(Router, {\n basename: basename,\n location: state.location,\n navigationType: state.historyAction,\n navigator: navigator\n }, state.initialized ? /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(DataRoutes, {\n routes: router.routes,\n state: state\n }) : fallbackElement))), null);\n}\nfunction DataRoutes(_ref2) {\n let { routes, state } = _ref2;\n return useRoutesImpl(routes, undefined, state);\n}\n/**\n * A <Router> that stores all entries in memory.\n *\n * @see https://reactrouter.com/router-components/memory-router\n */ function MemoryRouter(_ref3) {\n let { basename, children, initialEntries, initialIndex, future } = _ref3;\n let historyRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef();\n if (historyRef.current == null) {\n historyRef.current = (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.createMemoryHistory)({\n initialEntries,\n initialIndex,\n v5Compat: true\n });\n }\n let history = historyRef.current;\n let [state, setStateImpl] = react__WEBPACK_IMPORTED_MODULE_0__.useState({\n action: history.action,\n location: history.location\n });\n let { v7_startTransition } = future || {};\n let setState = react__WEBPACK_IMPORTED_MODULE_0__.useCallback((newState)=>{\n v7_startTransition && startTransitionImpl ? startTransitionImpl(()=>setStateImpl(newState)) : setStateImpl(newState);\n }, [\n setStateImpl,\n v7_startTransition\n ]);\n react__WEBPACK_IMPORTED_MODULE_0__.useLayoutEffect(()=>history.listen(setState), [\n history,\n setState\n ]);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(Router, {\n basename: basename,\n children: children,\n location: state.location,\n navigationType: state.action,\n navigator: history\n });\n}\n/**\n * Changes the current location.\n *\n * Note: This API is mostly useful in React.Component subclasses that are not\n * able to use hooks. In functional components, we recommend you use the\n * `useNavigate` hook instead.\n *\n * @see https://reactrouter.com/components/navigate\n */ function Navigate(_ref4) {\n let { to, replace, state, relative } = _ref4;\n !useInRouterContext() ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, // the router loaded. We can help them understand how to avoid that.\n \"<Navigate> may be used only in the context of a <Router> component.\") : 0 : void 0;\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(!react__WEBPACK_IMPORTED_MODULE_0__.useContext(NavigationContext).static, \"<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.\") : 0;\n let { matches } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(RouteContext);\n let { pathname: locationPathname } = useLocation();\n let navigate = useNavigate();\n // Resolve the path outside of the effect so that when effects run twice in\n // StrictMode they navigate to the same place\n let path = (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.resolveTo)(to, (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_getPathContributingMatches)(matches).map((match)=>match.pathnameBase), locationPathname, relative === \"path\");\n let jsonPath = JSON.stringify(path);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>navigate(JSON.parse(jsonPath), {\n replace,\n state,\n relative\n }), [\n navigate,\n jsonPath,\n relative,\n replace,\n state\n ]);\n return null;\n}\n/**\n * Renders the child route's element, if there is one.\n *\n * @see https://reactrouter.com/components/outlet\n */ function Outlet(props) {\n return useOutlet(props.context);\n}\n/**\n * Declares an element that should be rendered at a certain URL path.\n *\n * @see https://reactrouter.com/components/route\n */ function Route(_props) {\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.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>.\") : 0;\n}\n/**\n * Provides location context for the rest of the app.\n *\n * Note: You usually won't render a <Router> directly. Instead, you'll render a\n * router that is more specific to your environment such as a <BrowserRouter>\n * in web browsers or a <StaticRouter> for server rendering.\n *\n * @see https://reactrouter.com/router-components/router\n */ function Router(_ref5) {\n let { basename: basenameProp = \"/\", children = null, location: locationProp, navigationType = _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.Action.Pop, navigator, static: staticProp = false } = _ref5;\n !!useInRouterContext() ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"You cannot render a <Router> inside another <Router>.\" + \" You should never have more than one in your app.\") : 0 : void 0;\n // Preserve trailing slashes on basename, so we can let the user control\n // the enforcement of trailing slashes throughout the app\n let basename = basenameProp.replace(/^\\/*/, \"/\");\n let navigationContext = react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>({\n basename,\n navigator,\n static: staticProp\n }), [\n basename,\n navigator,\n staticProp\n ]);\n if (typeof locationProp === \"string\") {\n locationProp = (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.parsePath)(locationProp);\n }\n let { pathname = \"/\", search = \"\", hash = \"\", state = null, key = \"default\" } = locationProp;\n let locationContext = react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>{\n let trailingPathname = (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.stripBasename)(pathname, basename);\n if (trailingPathname == null) {\n return null;\n }\n return {\n location: {\n pathname: trailingPathname,\n search,\n hash,\n state,\n key\n },\n navigationType\n };\n }, [\n basename,\n pathname,\n search,\n hash,\n state,\n key,\n navigationType\n ]);\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.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.\") : 0;\n if (locationContext == null) {\n return null;\n }\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(NavigationContext.Provider, {\n value: navigationContext\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(LocationContext.Provider, {\n children: children,\n value: locationContext\n }));\n}\n/**\n * A container for a nested tree of <Route> elements that renders the branch\n * that best matches the current location.\n *\n * @see https://reactrouter.com/components/routes\n */ function Routes(_ref6) {\n let { children, location } = _ref6;\n return useRoutes(createRoutesFromChildren(children), location);\n}\n/**\n * Component to use for rendering lazily loaded data from returning defer()\n * in a loader function\n */ function Await(_ref7) {\n let { children, errorElement, resolve } = _ref7;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(AwaitErrorBoundary, {\n resolve: resolve,\n errorElement: errorElement\n }, /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(ResolveAwait, null, children));\n}\nvar AwaitRenderStatus = /*#__PURE__*/ function(AwaitRenderStatus) {\n AwaitRenderStatus[AwaitRenderStatus[\"pending\"] = 0] = \"pending\";\n AwaitRenderStatus[AwaitRenderStatus[\"success\"] = 1] = \"success\";\n AwaitRenderStatus[AwaitRenderStatus[\"error\"] = 2] = \"error\";\n return AwaitRenderStatus;\n}(AwaitRenderStatus || {});\nconst neverSettledPromise = new Promise(()=>{});\nclass AwaitErrorBoundary extends react__WEBPACK_IMPORTED_MODULE_0__.Component {\n constructor(props){\n super(props);\n this.state = {\n error: null\n };\n }\n static getDerivedStateFromError(error) {\n return {\n error\n };\n }\n componentDidCatch(error, errorInfo) {\n console.error(\"<Await> caught the following error during render\", error, errorInfo);\n }\n render() {\n let { children, errorElement, resolve } = this.props;\n let promise = null;\n let status = AwaitRenderStatus.pending;\n if (!(resolve instanceof Promise)) {\n // Didn't get a promise - provide as a resolved promise\n status = AwaitRenderStatus.success;\n promise = Promise.resolve();\n Object.defineProperty(promise, \"_tracked\", {\n get: ()=>true\n });\n Object.defineProperty(promise, \"_data\", {\n get: ()=>resolve\n });\n } else if (this.state.error) {\n // Caught a render error, provide it as a rejected promise\n status = AwaitRenderStatus.error;\n let renderError = this.state.error;\n promise = Promise.reject().catch(()=>{}); // Avoid unhandled rejection warnings\n Object.defineProperty(promise, \"_tracked\", {\n get: ()=>true\n });\n Object.defineProperty(promise, \"_error\", {\n get: ()=>renderError\n });\n } else if (resolve._tracked) {\n // Already tracked promise - check contents\n promise = resolve;\n status = promise._error !== undefined ? AwaitRenderStatus.error : promise._data !== undefined ? AwaitRenderStatus.success : AwaitRenderStatus.pending;\n } else {\n // Raw (untracked) promise - track it\n status = AwaitRenderStatus.pending;\n Object.defineProperty(resolve, \"_tracked\", {\n get: ()=>true\n });\n promise = resolve.then((data)=>Object.defineProperty(resolve, \"_data\", {\n get: ()=>data\n }), (error)=>Object.defineProperty(resolve, \"_error\", {\n get: ()=>error\n }));\n }\n if (status === AwaitRenderStatus.error && promise._error instanceof _remix_run_router__WEBPACK_IMPORTED_MODULE_1__.AbortedDeferredError) {\n // Freeze the UI by throwing a never resolved promise\n throw neverSettledPromise;\n }\n if (status === AwaitRenderStatus.error && !errorElement) {\n // No errorElement, throw to the nearest route-level error boundary\n throw promise._error;\n }\n if (status === AwaitRenderStatus.error) {\n // Render via our errorElement\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(AwaitContext.Provider, {\n value: promise,\n children: errorElement\n });\n }\n if (status === AwaitRenderStatus.success) {\n // Render children with resolved value\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(AwaitContext.Provider, {\n value: promise,\n children: children\n });\n }\n // Throw to the suspense boundary\n throw promise;\n }\n}\n/**\n * @private\n * Indirection to leverage useAsyncValue for a render-prop API on <Await>\n */ function ResolveAwait(_ref8) {\n let { children } = _ref8;\n let data = useAsyncValue();\n let toRender = typeof children === \"function\" ? children(data) : children;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(react__WEBPACK_IMPORTED_MODULE_0__.Fragment, null, toRender);\n}\n///////////////////////////////////////////////////////////////////////////////\n// UTILS\n///////////////////////////////////////////////////////////////////////////////\n/**\n * Creates a route config from a React \"children\" object, which is usually\n * either a `<Route>` element or an array of them. Used internally by\n * `<Routes>` to create a route config from its children.\n *\n * @see https://reactrouter.com/utils/create-routes-from-children\n */ function createRoutesFromChildren(children, parentPath) {\n if (parentPath === void 0) {\n parentPath = [];\n }\n let routes = [];\n react__WEBPACK_IMPORTED_MODULE_0__.Children.forEach(children, (element, index)=>{\n if (!/*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.isValidElement(element)) {\n // Ignore non-elements. This allows people to more easily inline\n // conditionals in their route config.\n return;\n }\n let treePath = [\n ...parentPath,\n index\n ];\n if (element.type === react__WEBPACK_IMPORTED_MODULE_0__.Fragment) {\n // Transparently support React.Fragment and its children.\n routes.push.apply(routes, createRoutesFromChildren(element.props.children, treePath));\n return;\n }\n !(element.type === Route) ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.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>\") : 0 : void 0;\n !(!element.props.index || !element.props.children) ? true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"An index route cannot have child routes.\") : 0 : void 0;\n let route = {\n id: element.props.id || treePath.join(\"-\"),\n caseSensitive: element.props.caseSensitive,\n element: element.props.element,\n Component: element.props.Component,\n index: element.props.index,\n path: element.props.path,\n loader: element.props.loader,\n action: element.props.action,\n errorElement: element.props.errorElement,\n ErrorBoundary: element.props.ErrorBoundary,\n hasErrorBoundary: element.props.ErrorBoundary != null || element.props.errorElement != null,\n shouldRevalidate: element.props.shouldRevalidate,\n handle: element.props.handle,\n lazy: element.props.lazy\n };\n if (element.props.children) {\n route.children = createRoutesFromChildren(element.props.children, treePath);\n }\n routes.push(route);\n });\n return routes;\n}\n/**\n * Renders the result of `matchRoutes()` into a React element.\n */ function renderMatches(matches) {\n return _renderMatches(matches);\n}\nfunction mapRouteProperties(route) {\n let updates = {\n // Note: this check also occurs in createRoutesFromChildren so update\n // there if you change this -- please and thank you!\n hasErrorBoundary: route.ErrorBoundary != null || route.errorElement != null\n };\n if (route.Component) {\n if (true) {\n if (route.element) {\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(false, \"You should not include both `Component` and `element` on your route - \" + \"`Component` will be used.\") : 0;\n }\n }\n Object.assign(updates, {\n element: /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(route.Component),\n Component: undefined\n });\n }\n if (route.ErrorBoundary) {\n if (true) {\n if (route.errorElement) {\n true ? (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(false, \"You should not include both `ErrorBoundary` and `errorElement` on your route - \" + \"`ErrorBoundary` will be used.\") : 0;\n }\n }\n Object.assign(updates, {\n errorElement: /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(route.ErrorBoundary),\n ErrorBoundary: undefined\n });\n }\n return updates;\n}\nfunction createMemoryRouter(routes, opts) {\n return (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.createRouter)({\n basename: opts == null ? void 0 : opts.basename,\n future: _extends({}, opts == null ? void 0 : opts.future, {\n v7_prependBasename: true\n }),\n history: (0,_remix_run_router__WEBPACK_IMPORTED_MODULE_1__.createMemoryHistory)({\n initialEntries: opts == null ? void 0 : opts.initialEntries,\n initialIndex: opts == null ? void 0 : opts.initialIndex\n }),\n hydrationData: opts == null ? void 0 : opts.hydrationData,\n routes,\n mapRouteProperties\n }).initialize();\n}\n //# sourceMappingURL=index.js.map\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/react-router/dist/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/react-router/dist/index.js?2a1f"],"sourcesContent":["/**\n * React Router v6.15.0\n *\n * Copyright (c) Remix Software Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE.md file in the root directory of this source tree.\n *\n * @license MIT\n */\nimport * as React from 'react';\nimport { UNSAFE_invariant, joinPaths, matchPath, UNSAFE_getPathContributingMatches, UNSAFE_warning, resolveTo, parsePath, matchRoutes, Action, stripBasename, IDLE_BLOCKER, isRouteErrorResponse, createMemoryHistory, AbortedDeferredError, createRouter } from '@remix-run/router';\nexport { AbortedDeferredError, Action as NavigationType, createPath, defer, generatePath, isRouteErrorResponse, json, matchPath, matchRoutes, parsePath, redirect, redirectDocument, resolvePath } from '@remix-run/router';\n\nfunction _extends() {\n  _extends = Object.assign ? Object.assign.bind() : function (target) {\n    for (var i = 1; i < arguments.length; i++) {\n      var source = arguments[i];\n      for (var key in source) {\n        if (Object.prototype.hasOwnProperty.call(source, key)) {\n          target[key] = source[key];\n        }\n      }\n    }\n    return target;\n  };\n  return _extends.apply(this, arguments);\n}\n\n// Create react-specific types from the agnostic types in @remix-run/router to\n// export from react-router\nconst DataRouterContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") {\n  DataRouterContext.displayName = \"DataRouter\";\n}\nconst DataRouterStateContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") {\n  DataRouterStateContext.displayName = \"DataRouterState\";\n}\nconst AwaitContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") {\n  AwaitContext.displayName = \"Await\";\n}\n\n/**\n * A Navigator is a \"location changer\"; it's how you get to different locations.\n *\n * Every history instance conforms to the Navigator interface, but the\n * distinction is useful primarily when it comes to the low-level <Router> API\n * where both the location and a navigator must be provided separately in order\n * to avoid \"tearing\" that may occur in a suspense-enabled app if the action\n * and/or location were to be read directly from the history instance.\n */\n\nconst NavigationContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") {\n  NavigationContext.displayName = \"Navigation\";\n}\nconst LocationContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") {\n  LocationContext.displayName = \"Location\";\n}\nconst RouteContext = /*#__PURE__*/React.createContext({\n  outlet: null,\n  matches: [],\n  isDataRoute: false\n});\nif (process.env.NODE_ENV !== \"production\") {\n  RouteContext.displayName = \"Route\";\n}\nconst RouteErrorContext = /*#__PURE__*/React.createContext(null);\nif (process.env.NODE_ENV !== \"production\") {\n  RouteErrorContext.displayName = \"RouteError\";\n}\n\n/**\n * Returns the full href for the given \"to\" value. This is useful for building\n * custom links that are also accessible and preserve right-click behavior.\n *\n * @see https://reactrouter.com/hooks/use-href\n */\nfunction useHref(to, _temp) {\n  let {\n    relative\n  } = _temp === void 0 ? {} : _temp;\n  !useInRouterContext() ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the\n  // router loaded. We can help them understand how to avoid that.\n  \"useHref() may be used only in the context of a <Router> component.\") : UNSAFE_invariant(false) : void 0;\n  let {\n    basename,\n    navigator\n  } = React.useContext(NavigationContext);\n  let {\n    hash,\n    pathname,\n    search\n  } = useResolvedPath(to, {\n    relative\n  });\n  let joinedPathname = pathname;\n\n  // If we're operating within a basename, prepend it to the pathname prior\n  // to creating the href.  If this is a root navigation, then just use the raw\n  // basename which allows the basename to have full control over the presence\n  // of a trailing slash on root links\n  if (basename !== \"/\") {\n    joinedPathname = pathname === \"/\" ? basename : joinPaths([basename, pathname]);\n  }\n  return navigator.createHref({\n    pathname: joinedPathname,\n    search,\n    hash\n  });\n}\n\n/**\n * Returns true if this component is a descendant of a <Router>.\n *\n * @see https://reactrouter.com/hooks/use-in-router-context\n */\nfunction useInRouterContext() {\n  return React.useContext(LocationContext) != null;\n}\n\n/**\n * Returns the current location object, which represents the current URL in web\n * browsers.\n *\n * Note: If you're using this it may mean you're doing some of your own\n * \"routing\" in your app, and we'd like to know what your use case is. We may\n * be able to provide something higher-level to better suit your needs.\n *\n * @see https://reactrouter.com/hooks/use-location\n */\nfunction useLocation() {\n  !useInRouterContext() ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the\n  // router loaded. We can help them understand how to avoid that.\n  \"useLocation() may be used only in the context of a <Router> component.\") : UNSAFE_invariant(false) : void 0;\n  return React.useContext(LocationContext).location;\n}\n\n/**\n * Returns the current navigation action which describes how the router came to\n * the current location, either by a pop, push, or replace on the history stack.\n *\n * @see https://reactrouter.com/hooks/use-navigation-type\n */\nfunction useNavigationType() {\n  return React.useContext(LocationContext).navigationType;\n}\n\n/**\n * Returns a PathMatch object if the given pattern matches the current URL.\n * This is useful for components that need to know \"active\" state, e.g.\n * <NavLink>.\n *\n * @see https://reactrouter.com/hooks/use-match\n */\nfunction useMatch(pattern) {\n  !useInRouterContext() ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the\n  // router loaded. We can help them understand how to avoid that.\n  \"useMatch() may be used only in the context of a <Router> component.\") : UNSAFE_invariant(false) : void 0;\n  let {\n    pathname\n  } = useLocation();\n  return React.useMemo(() => matchPath(pattern, pathname), [pathname, pattern]);\n}\n\n/**\n * The interface for the navigate() function returned from useNavigate().\n */\n\nconst navigateEffectWarning = \"You should call navigate() in a React.useEffect(), not when \" + \"your component is first rendered.\";\n\n// Mute warnings for calls to useNavigate in SSR environments\nfunction useIsomorphicLayoutEffect(cb) {\n  let isStatic = React.useContext(NavigationContext).static;\n  if (!isStatic) {\n    // We should be able to get rid of this once react 18.3 is released\n    // See: https://github.com/facebook/react/pull/26395\n    // eslint-disable-next-line react-hooks/rules-of-hooks\n    React.useLayoutEffect(cb);\n  }\n}\n\n/**\n * Returns an imperative method for changing the location. Used by <Link>s, but\n * may also be used by other elements to change the location.\n *\n * @see https://reactrouter.com/hooks/use-navigate\n */\nfunction useNavigate() {\n  let {\n    isDataRoute\n  } = React.useContext(RouteContext);\n  // Conditional usage is OK here because the usage of a data router is static\n  // eslint-disable-next-line react-hooks/rules-of-hooks\n  return isDataRoute ? useNavigateStable() : useNavigateUnstable();\n}\nfunction useNavigateUnstable() {\n  !useInRouterContext() ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the\n  // router loaded. We can help them understand how to avoid that.\n  \"useNavigate() may be used only in the context of a <Router> component.\") : UNSAFE_invariant(false) : void 0;\n  let dataRouterContext = React.useContext(DataRouterContext);\n  let {\n    basename,\n    navigator\n  } = React.useContext(NavigationContext);\n  let {\n    matches\n  } = React.useContext(RouteContext);\n  let {\n    pathname: locationPathname\n  } = useLocation();\n  let routePathnamesJson = JSON.stringify(UNSAFE_getPathContributingMatches(matches).map(match => match.pathnameBase));\n  let activeRef = React.useRef(false);\n  useIsomorphicLayoutEffect(() => {\n    activeRef.current = true;\n  });\n  let navigate = React.useCallback(function (to, options) {\n    if (options === void 0) {\n      options = {};\n    }\n    process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(activeRef.current, navigateEffectWarning) : void 0;\n\n    // Short circuit here since if this happens on first render the navigate\n    // is useless because we haven't wired up our history listener yet\n    if (!activeRef.current) return;\n    if (typeof to === \"number\") {\n      navigator.go(to);\n      return;\n    }\n    let path = resolveTo(to, JSON.parse(routePathnamesJson), locationPathname, options.relative === \"path\");\n\n    // If we're operating within a basename, prepend it to the pathname prior\n    // to handing off to history (but only if we're not in a data router,\n    // otherwise it'll prepend the basename inside of the router).\n    // If this is a root navigation, then we navigate to the raw basename\n    // which allows the basename to have full control over the presence of a\n    // trailing slash on root links\n    if (dataRouterContext == null && basename !== \"/\") {\n      path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n    }\n    (!!options.replace ? navigator.replace : navigator.push)(path, options.state, options);\n  }, [basename, navigator, routePathnamesJson, locationPathname, dataRouterContext]);\n  return navigate;\n}\nconst OutletContext = /*#__PURE__*/React.createContext(null);\n\n/**\n * Returns the context (if provided) for the child route at this level of the route\n * hierarchy.\n * @see https://reactrouter.com/hooks/use-outlet-context\n */\nfunction useOutletContext() {\n  return React.useContext(OutletContext);\n}\n\n/**\n * Returns the element for the child route at this level of the route\n * hierarchy. Used internally by <Outlet> to render child routes.\n *\n * @see https://reactrouter.com/hooks/use-outlet\n */\nfunction useOutlet(context) {\n  let outlet = React.useContext(RouteContext).outlet;\n  if (outlet) {\n    return /*#__PURE__*/React.createElement(OutletContext.Provider, {\n      value: context\n    }, outlet);\n  }\n  return outlet;\n}\n\n/**\n * Returns an object of key/value pairs of the dynamic params from the current\n * URL that were matched by the route path.\n *\n * @see https://reactrouter.com/hooks/use-params\n */\nfunction useParams() {\n  let {\n    matches\n  } = React.useContext(RouteContext);\n  let routeMatch = matches[matches.length - 1];\n  return routeMatch ? routeMatch.params : {};\n}\n\n/**\n * Resolves the pathname of the given `to` value against the current location.\n *\n * @see https://reactrouter.com/hooks/use-resolved-path\n */\nfunction useResolvedPath(to, _temp2) {\n  let {\n    relative\n  } = _temp2 === void 0 ? {} : _temp2;\n  let {\n    matches\n  } = React.useContext(RouteContext);\n  let {\n    pathname: locationPathname\n  } = useLocation();\n  let routePathnamesJson = JSON.stringify(UNSAFE_getPathContributingMatches(matches).map(match => match.pathnameBase));\n  return React.useMemo(() => resolveTo(to, JSON.parse(routePathnamesJson), locationPathname, relative === \"path\"), [to, routePathnamesJson, locationPathname, relative]);\n}\n\n/**\n * Returns the element of the route that matched the current location, prepared\n * with the correct context to render the remainder of the route tree. Route\n * elements in the tree must render an <Outlet> to render their child route's\n * element.\n *\n * @see https://reactrouter.com/hooks/use-routes\n */\nfunction useRoutes(routes, locationArg) {\n  return useRoutesImpl(routes, locationArg);\n}\n\n// Internal implementation with accept optional param for RouterProvider usage\nfunction useRoutesImpl(routes, locationArg, dataRouterState) {\n  !useInRouterContext() ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of the\n  // router loaded. We can help them understand how to avoid that.\n  \"useRoutes() may be used only in the context of a <Router> component.\") : UNSAFE_invariant(false) : void 0;\n  let {\n    navigator\n  } = React.useContext(NavigationContext);\n  let {\n    matches: parentMatches\n  } = React.useContext(RouteContext);\n  let routeMatch = parentMatches[parentMatches.length - 1];\n  let parentParams = routeMatch ? routeMatch.params : {};\n  let parentPathname = routeMatch ? routeMatch.pathname : \"/\";\n  let parentPathnameBase = routeMatch ? routeMatch.pathnameBase : \"/\";\n  let parentRoute = routeMatch && routeMatch.route;\n  if (process.env.NODE_ENV !== \"production\") {\n    // You won't get a warning about 2 different <Routes> under a <Route>\n    // without a trailing *, but this is a best-effort warning anyway since we\n    // cannot even give the warning unless they land at the parent route.\n    //\n    // Example:\n    //\n    // <Routes>\n    //   {/* This route path MUST end with /* because otherwise\n    //       it will never match /blog/post/123 */}\n    //   <Route path=\"blog\" element={<Blog />} />\n    //   <Route path=\"blog/feed\" element={<BlogFeed />} />\n    // </Routes>\n    //\n    // function Blog() {\n    //   return (\n    //     <Routes>\n    //       <Route path=\"post/:id\" element={<Post />} />\n    //     </Routes>\n    //   );\n    // }\n    let parentPath = parentRoute && parentRoute.path || \"\";\n    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 + \"/*\") + \"\\\">.\"));\n  }\n  let locationFromContext = useLocation();\n  let location;\n  if (locationArg) {\n    var _parsedLocationArg$pa;\n    let parsedLocationArg = typeof locationArg === \"string\" ? parsePath(locationArg) : locationArg;\n    !(parentPathnameBase === \"/\" || ((_parsedLocationArg$pa = parsedLocationArg.pathname) == null ? void 0 : _parsedLocationArg$pa.startsWith(parentPathnameBase))) ? process.env.NODE_ENV !== \"production\" ? 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.\")) : UNSAFE_invariant(false) : void 0;\n    location = parsedLocationArg;\n  } else {\n    location = locationFromContext;\n  }\n  let pathname = location.pathname || \"/\";\n  let remainingPathname = parentPathnameBase === \"/\" ? pathname : pathname.slice(parentPathnameBase.length) || \"/\";\n  let matches = matchRoutes(routes, {\n    pathname: remainingPathname\n  });\n  if (process.env.NODE_ENV !== \"production\") {\n    process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(parentRoute || matches != null, \"No routes matched location \\\"\" + location.pathname + location.search + location.hash + \"\\\" \") : void 0;\n    process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(matches == null || matches[matches.length - 1].route.element !== undefined || matches[matches.length - 1].route.Component !== 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.\") : void 0;\n  }\n  let renderedMatches = _renderMatches(matches && matches.map(match => Object.assign({}, match, {\n    params: Object.assign({}, parentParams, match.params),\n    pathname: joinPaths([parentPathnameBase,\n    // Re-encode pathnames that were decoded inside matchRoutes\n    navigator.encodeLocation ? navigator.encodeLocation(match.pathname).pathname : match.pathname]),\n    pathnameBase: match.pathnameBase === \"/\" ? parentPathnameBase : joinPaths([parentPathnameBase,\n    // Re-encode pathnames that were decoded inside matchRoutes\n    navigator.encodeLocation ? navigator.encodeLocation(match.pathnameBase).pathname : match.pathnameBase])\n  })), parentMatches, dataRouterState);\n\n  // When a user passes in a `locationArg`, the associated routes need to\n  // be wrapped in a new `LocationContext.Provider` in order for `useLocation`\n  // to use the scoped location instead of the global location.\n  if (locationArg && renderedMatches) {\n    return /*#__PURE__*/React.createElement(LocationContext.Provider, {\n      value: {\n        location: _extends({\n          pathname: \"/\",\n          search: \"\",\n          hash: \"\",\n          state: null,\n          key: \"default\"\n        }, location),\n        navigationType: Action.Pop\n      }\n    }, renderedMatches);\n  }\n  return renderedMatches;\n}\nfunction DefaultErrorComponent() {\n  let error = useRouteError();\n  let message = isRouteErrorResponse(error) ? error.status + \" \" + error.statusText : error instanceof Error ? error.message : JSON.stringify(error);\n  let stack = error instanceof Error ? error.stack : null;\n  let lightgrey = \"rgba(200,200,200, 0.5)\";\n  let preStyles = {\n    padding: \"0.5rem\",\n    backgroundColor: lightgrey\n  };\n  let codeStyles = {\n    padding: \"2px 4px\",\n    backgroundColor: lightgrey\n  };\n  let devInfo = null;\n  if (process.env.NODE_ENV !== \"production\") {\n    console.error(\"Error handled by React Router default ErrorBoundary:\", error);\n    devInfo = /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(\"p\", null, \"\\uD83D\\uDCBF Hey developer \\uD83D\\uDC4B\"), /*#__PURE__*/React.createElement(\"p\", null, \"You can provide a way better UX than this when your app throws errors by providing your own \", /*#__PURE__*/React.createElement(\"code\", {\n      style: codeStyles\n    }, \"ErrorBoundary\"), \" or\", \" \", /*#__PURE__*/React.createElement(\"code\", {\n      style: codeStyles\n    }, \"errorElement\"), \" prop on your route.\"));\n  }\n  return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(\"h2\", null, \"Unexpected Application Error!\"), /*#__PURE__*/React.createElement(\"h3\", {\n    style: {\n      fontStyle: \"italic\"\n    }\n  }, message), stack ? /*#__PURE__*/React.createElement(\"pre\", {\n    style: preStyles\n  }, stack) : null, devInfo);\n}\nconst defaultErrorElement = /*#__PURE__*/React.createElement(DefaultErrorComponent, null);\nclass RenderErrorBoundary extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      location: props.location,\n      revalidation: props.revalidation,\n      error: props.error\n    };\n  }\n  static getDerivedStateFromError(error) {\n    return {\n      error: error\n    };\n  }\n  static getDerivedStateFromProps(props, state) {\n    // When we get into an error state, the user will likely click \"back\" to the\n    // previous page that didn't have an error. Because this wraps the entire\n    // application, that will have no effect--the error page continues to display.\n    // This gives us a mechanism to recover from the error when the location changes.\n    //\n    // Whether we're in an error state or not, we update the location in state\n    // so that when we are in an error state, it gets reset when a new location\n    // comes in and the user recovers from the error.\n    if (state.location !== props.location || state.revalidation !== \"idle\" && props.revalidation === \"idle\") {\n      return {\n        error: props.error,\n        location: props.location,\n        revalidation: props.revalidation\n      };\n    }\n\n    // If we're not changing locations, preserve the location but still surface\n    // any new errors that may come through. We retain the existing error, we do\n    // this because the error provided from the app state may be cleared without\n    // the location changing.\n    return {\n      error: props.error || state.error,\n      location: state.location,\n      revalidation: props.revalidation || state.revalidation\n    };\n  }\n  componentDidCatch(error, errorInfo) {\n    console.error(\"React Router caught the following error during render\", error, errorInfo);\n  }\n  render() {\n    return this.state.error ? /*#__PURE__*/React.createElement(RouteContext.Provider, {\n      value: this.props.routeContext\n    }, /*#__PURE__*/React.createElement(RouteErrorContext.Provider, {\n      value: this.state.error,\n      children: this.props.component\n    })) : this.props.children;\n  }\n}\nfunction RenderedRoute(_ref) {\n  let {\n    routeContext,\n    match,\n    children\n  } = _ref;\n  let dataRouterContext = React.useContext(DataRouterContext);\n\n  // Track how deep we got in our render pass to emulate SSR componentDidCatch\n  // in a DataStaticRouter\n  if (dataRouterContext && dataRouterContext.static && dataRouterContext.staticContext && (match.route.errorElement || match.route.ErrorBoundary)) {\n    dataRouterContext.staticContext._deepestRenderedBoundaryId = match.route.id;\n  }\n  return /*#__PURE__*/React.createElement(RouteContext.Provider, {\n    value: routeContext\n  }, children);\n}\nfunction _renderMatches(matches, parentMatches, dataRouterState) {\n  var _dataRouterState2;\n  if (parentMatches === void 0) {\n    parentMatches = [];\n  }\n  if (dataRouterState === void 0) {\n    dataRouterState = null;\n  }\n  if (matches == null) {\n    var _dataRouterState;\n    if ((_dataRouterState = dataRouterState) != null && _dataRouterState.errors) {\n      // Don't bail if we have data router errors so we can render them in the\n      // boundary.  Use the pre-matched (or shimmed) matches\n      matches = dataRouterState.matches;\n    } else {\n      return null;\n    }\n  }\n  let renderedMatches = matches;\n\n  // If we have data errors, trim matches to the highest error boundary\n  let errors = (_dataRouterState2 = dataRouterState) == null ? void 0 : _dataRouterState2.errors;\n  if (errors != null) {\n    let errorIndex = renderedMatches.findIndex(m => m.route.id && (errors == null ? void 0 : errors[m.route.id]));\n    !(errorIndex >= 0) ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"Could not find a matching route for errors on route IDs: \" + Object.keys(errors).join(\",\")) : UNSAFE_invariant(false) : void 0;\n    renderedMatches = renderedMatches.slice(0, Math.min(renderedMatches.length, errorIndex + 1));\n  }\n  return renderedMatches.reduceRight((outlet, match, index) => {\n    let error = match.route.id ? errors == null ? void 0 : errors[match.route.id] : null;\n    // Only data routers handle errors\n    let errorElement = null;\n    if (dataRouterState) {\n      errorElement = match.route.errorElement || defaultErrorElement;\n    }\n    let matches = parentMatches.concat(renderedMatches.slice(0, index + 1));\n    let getChildren = () => {\n      let children;\n      if (error) {\n        children = errorElement;\n      } else if (match.route.Component) {\n        // Note: This is a de-optimized path since React won't re-use the\n        // ReactElement since it's identity changes with each new\n        // React.createElement call.  We keep this so folks can use\n        // `<Route Component={...}>` in `<Routes>` but generally `Component`\n        // usage is only advised in `RouterProvider` when we can convert it to\n        // `element` ahead of time.\n        children = /*#__PURE__*/React.createElement(match.route.Component, null);\n      } else if (match.route.element) {\n        children = match.route.element;\n      } else {\n        children = outlet;\n      }\n      return /*#__PURE__*/React.createElement(RenderedRoute, {\n        match: match,\n        routeContext: {\n          outlet,\n          matches,\n          isDataRoute: dataRouterState != null\n        },\n        children: children\n      });\n    };\n    // Only wrap in an error boundary within data router usages when we have an\n    // ErrorBoundary/errorElement on this route.  Otherwise let it bubble up to\n    // an ancestor ErrorBoundary/errorElement\n    return dataRouterState && (match.route.ErrorBoundary || match.route.errorElement || index === 0) ? /*#__PURE__*/React.createElement(RenderErrorBoundary, {\n      location: dataRouterState.location,\n      revalidation: dataRouterState.revalidation,\n      component: errorElement,\n      error: error,\n      children: getChildren(),\n      routeContext: {\n        outlet: null,\n        matches,\n        isDataRoute: true\n      }\n    }) : getChildren();\n  }, null);\n}\nvar DataRouterHook = /*#__PURE__*/function (DataRouterHook) {\n  DataRouterHook[\"UseBlocker\"] = \"useBlocker\";\n  DataRouterHook[\"UseRevalidator\"] = \"useRevalidator\";\n  DataRouterHook[\"UseNavigateStable\"] = \"useNavigate\";\n  return DataRouterHook;\n}(DataRouterHook || {});\nvar DataRouterStateHook = /*#__PURE__*/function (DataRouterStateHook) {\n  DataRouterStateHook[\"UseBlocker\"] = \"useBlocker\";\n  DataRouterStateHook[\"UseLoaderData\"] = \"useLoaderData\";\n  DataRouterStateHook[\"UseActionData\"] = \"useActionData\";\n  DataRouterStateHook[\"UseRouteError\"] = \"useRouteError\";\n  DataRouterStateHook[\"UseNavigation\"] = \"useNavigation\";\n  DataRouterStateHook[\"UseRouteLoaderData\"] = \"useRouteLoaderData\";\n  DataRouterStateHook[\"UseMatches\"] = \"useMatches\";\n  DataRouterStateHook[\"UseRevalidator\"] = \"useRevalidator\";\n  DataRouterStateHook[\"UseNavigateStable\"] = \"useNavigate\";\n  DataRouterStateHook[\"UseRouteId\"] = \"useRouteId\";\n  return DataRouterStateHook;\n}(DataRouterStateHook || {});\nfunction getDataRouterConsoleError(hookName) {\n  return hookName + \" must be used within a data router.  See https://reactrouter.com/routers/picking-a-router.\";\n}\nfunction useDataRouterContext(hookName) {\n  let ctx = React.useContext(DataRouterContext);\n  !ctx ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, getDataRouterConsoleError(hookName)) : UNSAFE_invariant(false) : void 0;\n  return ctx;\n}\nfunction useDataRouterState(hookName) {\n  let state = React.useContext(DataRouterStateContext);\n  !state ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, getDataRouterConsoleError(hookName)) : UNSAFE_invariant(false) : void 0;\n  return state;\n}\nfunction useRouteContext(hookName) {\n  let route = React.useContext(RouteContext);\n  !route ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, getDataRouterConsoleError(hookName)) : UNSAFE_invariant(false) : void 0;\n  return route;\n}\n\n// Internal version with hookName-aware debugging\nfunction useCurrentRouteId(hookName) {\n  let route = useRouteContext(hookName);\n  let thisRoute = route.matches[route.matches.length - 1];\n  !thisRoute.route.id ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, hookName + \" can only be used on routes that contain a unique \\\"id\\\"\") : UNSAFE_invariant(false) : void 0;\n  return thisRoute.route.id;\n}\n\n/**\n * Returns the ID for the nearest contextual route\n */\nfunction useRouteId() {\n  return useCurrentRouteId(DataRouterStateHook.UseRouteId);\n}\n\n/**\n * Returns the current navigation, defaulting to an \"idle\" navigation when\n * no navigation is in progress\n */\nfunction useNavigation() {\n  let state = useDataRouterState(DataRouterStateHook.UseNavigation);\n  return state.navigation;\n}\n\n/**\n * Returns a revalidate function for manually triggering revalidation, as well\n * as the current state of any manual revalidations\n */\nfunction useRevalidator() {\n  let dataRouterContext = useDataRouterContext(DataRouterHook.UseRevalidator);\n  let state = useDataRouterState(DataRouterStateHook.UseRevalidator);\n  return React.useMemo(() => ({\n    revalidate: dataRouterContext.router.revalidate,\n    state: state.revalidation\n  }), [dataRouterContext.router.revalidate, state.revalidation]);\n}\n\n/**\n * Returns the active route matches, useful for accessing loaderData for\n * parent/child routes or the route \"handle\" property\n */\nfunction useMatches() {\n  let {\n    matches,\n    loaderData\n  } = useDataRouterState(DataRouterStateHook.UseMatches);\n  return React.useMemo(() => matches.map(match => {\n    let {\n      pathname,\n      params\n    } = match;\n    // Note: This structure matches that created by createUseMatchesMatch\n    // in the @remix-run/router , so if you change this please also change\n    // that :)  Eventually we'll DRY this up\n    return {\n      id: match.route.id,\n      pathname,\n      params,\n      data: loaderData[match.route.id],\n      handle: match.route.handle\n    };\n  }), [matches, loaderData]);\n}\n\n/**\n * Returns the loader data for the nearest ancestor Route loader\n */\nfunction useLoaderData() {\n  let state = useDataRouterState(DataRouterStateHook.UseLoaderData);\n  let routeId = useCurrentRouteId(DataRouterStateHook.UseLoaderData);\n  if (state.errors && state.errors[routeId] != null) {\n    console.error(\"You cannot `useLoaderData` in an errorElement (routeId: \" + routeId + \")\");\n    return undefined;\n  }\n  return state.loaderData[routeId];\n}\n\n/**\n * Returns the loaderData for the given routeId\n */\nfunction useRouteLoaderData(routeId) {\n  let state = useDataRouterState(DataRouterStateHook.UseRouteLoaderData);\n  return state.loaderData[routeId];\n}\n\n/**\n * Returns the action data for the nearest ancestor Route action\n */\nfunction useActionData() {\n  let state = useDataRouterState(DataRouterStateHook.UseActionData);\n  let route = React.useContext(RouteContext);\n  !route ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"useActionData must be used inside a RouteContext\") : UNSAFE_invariant(false) : void 0;\n  return Object.values((state == null ? void 0 : state.actionData) || {})[0];\n}\n\n/**\n * Returns the nearest ancestor Route error, which could be a loader/action\n * error or a render error.  This is intended to be called from your\n * ErrorBoundary/errorElement to display a proper error message.\n */\nfunction useRouteError() {\n  var _state$errors;\n  let error = React.useContext(RouteErrorContext);\n  let state = useDataRouterState(DataRouterStateHook.UseRouteError);\n  let routeId = useCurrentRouteId(DataRouterStateHook.UseRouteError);\n\n  // If this was a render error, we put it in a RouteError context inside\n  // of RenderErrorBoundary\n  if (error) {\n    return error;\n  }\n\n  // Otherwise look for errors from our data router state\n  return (_state$errors = state.errors) == null ? void 0 : _state$errors[routeId];\n}\n\n/**\n * Returns the happy-path data from the nearest ancestor <Await /> value\n */\nfunction useAsyncValue() {\n  let value = React.useContext(AwaitContext);\n  return value == null ? void 0 : value._data;\n}\n\n/**\n * Returns the error from the nearest ancestor <Await /> value\n */\nfunction useAsyncError() {\n  let value = React.useContext(AwaitContext);\n  return value == null ? void 0 : value._error;\n}\nlet blockerId = 0;\n\n/**\n * Allow the application to block navigations within the SPA and present the\n * user a confirmation dialog to confirm the navigation.  Mostly used to avoid\n * using half-filled form data.  This does not handle hard-reloads or\n * cross-origin navigations.\n */\nfunction useBlocker(shouldBlock) {\n  let {\n    router,\n    basename\n  } = useDataRouterContext(DataRouterHook.UseBlocker);\n  let state = useDataRouterState(DataRouterStateHook.UseBlocker);\n  let [blockerKey, setBlockerKey] = React.useState(\"\");\n  let blockerFunction = React.useCallback(arg => {\n    if (typeof shouldBlock !== \"function\") {\n      return !!shouldBlock;\n    }\n    if (basename === \"/\") {\n      return shouldBlock(arg);\n    }\n\n    // If they provided us a function and we've got an active basename, strip\n    // it from the locations we expose to the user to match the behavior of\n    // useLocation\n    let {\n      currentLocation,\n      nextLocation,\n      historyAction\n    } = arg;\n    return shouldBlock({\n      currentLocation: _extends({}, currentLocation, {\n        pathname: stripBasename(currentLocation.pathname, basename) || currentLocation.pathname\n      }),\n      nextLocation: _extends({}, nextLocation, {\n        pathname: stripBasename(nextLocation.pathname, basename) || nextLocation.pathname\n      }),\n      historyAction\n    });\n  }, [basename, shouldBlock]);\n\n  // This effect is in charge of blocker key assignment and deletion (which is\n  // tightly coupled to the key)\n  React.useEffect(() => {\n    let key = String(++blockerId);\n    setBlockerKey(key);\n    return () => router.deleteBlocker(key);\n  }, [router]);\n\n  // This effect handles assigning the blockerFunction.  This is to handle\n  // unstable blocker function identities, and happens only after the prior\n  // effect so we don't get an orphaned blockerFunction in the router with a\n  // key of \"\".  Until then we just have the IDLE_BLOCKER.\n  React.useEffect(() => {\n    if (blockerKey !== \"\") {\n      router.getBlocker(blockerKey, blockerFunction);\n    }\n  }, [router, blockerKey, blockerFunction]);\n\n  // Prefer the blocker from `state` not `router.state` since DataRouterContext\n  // is memoized so this ensures we update on blocker state updates\n  return blockerKey && state.blockers.has(blockerKey) ? state.blockers.get(blockerKey) : IDLE_BLOCKER;\n}\n\n/**\n * Stable version of useNavigate that is used when we are in the context of\n * a RouterProvider.\n */\nfunction useNavigateStable() {\n  let {\n    router\n  } = useDataRouterContext(DataRouterHook.UseNavigateStable);\n  let id = useCurrentRouteId(DataRouterStateHook.UseNavigateStable);\n  let activeRef = React.useRef(false);\n  useIsomorphicLayoutEffect(() => {\n    activeRef.current = true;\n  });\n  let navigate = React.useCallback(function (to, options) {\n    if (options === void 0) {\n      options = {};\n    }\n    process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(activeRef.current, navigateEffectWarning) : void 0;\n\n    // Short circuit here since if this happens on first render the navigate\n    // is useless because we haven't wired up our router subscriber yet\n    if (!activeRef.current) return;\n    if (typeof to === \"number\") {\n      router.navigate(to);\n    } else {\n      router.navigate(to, _extends({\n        fromRouteId: id\n      }, options));\n    }\n  }, [router, id]);\n  return navigate;\n}\nconst alreadyWarned = {};\nfunction warningOnce(key, cond, message) {\n  if (!cond && !alreadyWarned[key]) {\n    alreadyWarned[key] = true;\n    process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(false, message) : void 0;\n  }\n}\n\n/**\n  Webpack + React 17 fails to compile on any of the following because webpack\n  complains that `startTransition` doesn't exist in `React`:\n  * import { startTransition } from \"react\"\n  * import * as React from from \"react\";\n    \"startTransition\" in React ? React.startTransition(() => setState()) : setState()\n  * import * as React from from \"react\";\n    \"startTransition\" in React ? React[\"startTransition\"](() => setState()) : setState()\n\n  Moving it to a constant such as the following solves the Webpack/React 17 issue:\n  * import * as React from from \"react\";\n    const START_TRANSITION = \"startTransition\";\n    START_TRANSITION in React ? React[START_TRANSITION](() => setState()) : setState()\n\n  However, that introduces webpack/terser minification issues in production builds\n  in React 18 where minification/obfuscation ends up removing the call of\n  React.startTransition entirely from the first half of the ternary.  Grabbing\n  this exported reference once up front resolves that issue.\n\n  See https://github.com/remix-run/react-router/issues/10579\n*/\nconst START_TRANSITION = \"startTransition\";\nconst startTransitionImpl = React[START_TRANSITION];\n\n/**\n * Given a Remix Router instance, render the appropriate UI\n */\nfunction RouterProvider(_ref) {\n  let {\n    fallbackElement,\n    router,\n    future\n  } = _ref;\n  // Need to use a layout effect here so we are subscribed early enough to\n  // pick up on any render-driven redirects/navigations (useEffect/<Navigate>)\n  let [state, setStateImpl] = React.useState(router.state);\n  let {\n    v7_startTransition\n  } = future || {};\n  let setState = React.useCallback(newState => {\n    v7_startTransition && startTransitionImpl ? startTransitionImpl(() => setStateImpl(newState)) : setStateImpl(newState);\n  }, [setStateImpl, v7_startTransition]);\n  React.useLayoutEffect(() => router.subscribe(setState), [router, setState]);\n  let navigator = React.useMemo(() => {\n    return {\n      createHref: router.createHref,\n      encodeLocation: router.encodeLocation,\n      go: n => router.navigate(n),\n      push: (to, state, opts) => router.navigate(to, {\n        state,\n        preventScrollReset: opts == null ? void 0 : opts.preventScrollReset\n      }),\n      replace: (to, state, opts) => router.navigate(to, {\n        replace: true,\n        state,\n        preventScrollReset: opts == null ? void 0 : opts.preventScrollReset\n      })\n    };\n  }, [router]);\n  let basename = router.basename || \"/\";\n  let dataRouterContext = React.useMemo(() => ({\n    router,\n    navigator,\n    static: false,\n    basename\n  }), [router, navigator, basename]);\n\n  // The fragment and {null} here are important!  We need them to keep React 18's\n  // useId happy when we are server-rendering since we may have a <script> here\n  // containing the hydrated server-side staticContext (from StaticRouterProvider).\n  // useId relies on the component tree structure to generate deterministic id's\n  // so we need to ensure it remains the same on the client even though\n  // we don't need the <script> tag\n  return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(DataRouterContext.Provider, {\n    value: dataRouterContext\n  }, /*#__PURE__*/React.createElement(DataRouterStateContext.Provider, {\n    value: state\n  }, /*#__PURE__*/React.createElement(Router, {\n    basename: basename,\n    location: state.location,\n    navigationType: state.historyAction,\n    navigator: navigator\n  }, state.initialized ? /*#__PURE__*/React.createElement(DataRoutes, {\n    routes: router.routes,\n    state: state\n  }) : fallbackElement))), null);\n}\nfunction DataRoutes(_ref2) {\n  let {\n    routes,\n    state\n  } = _ref2;\n  return useRoutesImpl(routes, undefined, state);\n}\n/**\n * A <Router> that stores all entries in memory.\n *\n * @see https://reactrouter.com/router-components/memory-router\n */\nfunction MemoryRouter(_ref3) {\n  let {\n    basename,\n    children,\n    initialEntries,\n    initialIndex,\n    future\n  } = _ref3;\n  let historyRef = React.useRef();\n  if (historyRef.current == null) {\n    historyRef.current = createMemoryHistory({\n      initialEntries,\n      initialIndex,\n      v5Compat: true\n    });\n  }\n  let history = historyRef.current;\n  let [state, setStateImpl] = React.useState({\n    action: history.action,\n    location: history.location\n  });\n  let {\n    v7_startTransition\n  } = future || {};\n  let setState = React.useCallback(newState => {\n    v7_startTransition && startTransitionImpl ? startTransitionImpl(() => setStateImpl(newState)) : setStateImpl(newState);\n  }, [setStateImpl, v7_startTransition]);\n  React.useLayoutEffect(() => history.listen(setState), [history, setState]);\n  return /*#__PURE__*/React.createElement(Router, {\n    basename: basename,\n    children: children,\n    location: state.location,\n    navigationType: state.action,\n    navigator: history\n  });\n}\n/**\n * Changes the current location.\n *\n * Note: This API is mostly useful in React.Component subclasses that are not\n * able to use hooks. In functional components, we recommend you use the\n * `useNavigate` hook instead.\n *\n * @see https://reactrouter.com/components/navigate\n */\nfunction Navigate(_ref4) {\n  let {\n    to,\n    replace,\n    state,\n    relative\n  } = _ref4;\n  !useInRouterContext() ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, // TODO: This error is probably because they somehow have 2 versions of\n  // the router loaded. We can help them understand how to avoid that.\n  \"<Navigate> may be used only in the context of a <Router> component.\") : UNSAFE_invariant(false) : void 0;\n  process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(!React.useContext(NavigationContext).static, \"<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.\") : void 0;\n  let {\n    matches\n  } = React.useContext(RouteContext);\n  let {\n    pathname: locationPathname\n  } = useLocation();\n  let navigate = useNavigate();\n\n  // Resolve the path outside of the effect so that when effects run twice in\n  // StrictMode they navigate to the same place\n  let path = resolveTo(to, UNSAFE_getPathContributingMatches(matches).map(match => match.pathnameBase), locationPathname, relative === \"path\");\n  let jsonPath = JSON.stringify(path);\n  React.useEffect(() => navigate(JSON.parse(jsonPath), {\n    replace,\n    state,\n    relative\n  }), [navigate, jsonPath, relative, replace, state]);\n  return null;\n}\n/**\n * Renders the child route's element, if there is one.\n *\n * @see https://reactrouter.com/components/outlet\n */\nfunction Outlet(props) {\n  return useOutlet(props.context);\n}\n/**\n * Declares an element that should be rendered at a certain URL path.\n *\n * @see https://reactrouter.com/components/route\n */\nfunction Route(_props) {\n  process.env.NODE_ENV !== \"production\" ? 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>.\") : UNSAFE_invariant(false) ;\n}\n/**\n * Provides location context for the rest of the app.\n *\n * Note: You usually won't render a <Router> directly. Instead, you'll render a\n * router that is more specific to your environment such as a <BrowserRouter>\n * in web browsers or a <StaticRouter> for server rendering.\n *\n * @see https://reactrouter.com/router-components/router\n */\nfunction Router(_ref5) {\n  let {\n    basename: basenameProp = \"/\",\n    children = null,\n    location: locationProp,\n    navigationType = Action.Pop,\n    navigator,\n    static: staticProp = false\n  } = _ref5;\n  !!useInRouterContext() ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"You cannot render a <Router> inside another <Router>.\" + \" You should never have more than one in your app.\") : UNSAFE_invariant(false) : void 0;\n\n  // Preserve trailing slashes on basename, so we can let the user control\n  // the enforcement of trailing slashes throughout the app\n  let basename = basenameProp.replace(/^\\/*/, \"/\");\n  let navigationContext = React.useMemo(() => ({\n    basename,\n    navigator,\n    static: staticProp\n  }), [basename, navigator, staticProp]);\n  if (typeof locationProp === \"string\") {\n    locationProp = parsePath(locationProp);\n  }\n  let {\n    pathname = \"/\",\n    search = \"\",\n    hash = \"\",\n    state = null,\n    key = \"default\"\n  } = locationProp;\n  let locationContext = React.useMemo(() => {\n    let trailingPathname = stripBasename(pathname, basename);\n    if (trailingPathname == null) {\n      return null;\n    }\n    return {\n      location: {\n        pathname: trailingPathname,\n        search,\n        hash,\n        state,\n        key\n      },\n      navigationType\n    };\n  }, [basename, pathname, search, hash, state, key, navigationType]);\n  process.env.NODE_ENV !== \"production\" ? 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.\") : void 0;\n  if (locationContext == null) {\n    return null;\n  }\n  return /*#__PURE__*/React.createElement(NavigationContext.Provider, {\n    value: navigationContext\n  }, /*#__PURE__*/React.createElement(LocationContext.Provider, {\n    children: children,\n    value: locationContext\n  }));\n}\n/**\n * A container for a nested tree of <Route> elements that renders the branch\n * that best matches the current location.\n *\n * @see https://reactrouter.com/components/routes\n */\nfunction Routes(_ref6) {\n  let {\n    children,\n    location\n  } = _ref6;\n  return useRoutes(createRoutesFromChildren(children), location);\n}\n/**\n * Component to use for rendering lazily loaded data from returning defer()\n * in a loader function\n */\nfunction Await(_ref7) {\n  let {\n    children,\n    errorElement,\n    resolve\n  } = _ref7;\n  return /*#__PURE__*/React.createElement(AwaitErrorBoundary, {\n    resolve: resolve,\n    errorElement: errorElement\n  }, /*#__PURE__*/React.createElement(ResolveAwait, null, children));\n}\nvar AwaitRenderStatus = /*#__PURE__*/function (AwaitRenderStatus) {\n  AwaitRenderStatus[AwaitRenderStatus[\"pending\"] = 0] = \"pending\";\n  AwaitRenderStatus[AwaitRenderStatus[\"success\"] = 1] = \"success\";\n  AwaitRenderStatus[AwaitRenderStatus[\"error\"] = 2] = \"error\";\n  return AwaitRenderStatus;\n}(AwaitRenderStatus || {});\nconst neverSettledPromise = new Promise(() => {});\nclass AwaitErrorBoundary extends React.Component {\n  constructor(props) {\n    super(props);\n    this.state = {\n      error: null\n    };\n  }\n  static getDerivedStateFromError(error) {\n    return {\n      error\n    };\n  }\n  componentDidCatch(error, errorInfo) {\n    console.error(\"<Await> caught the following error during render\", error, errorInfo);\n  }\n  render() {\n    let {\n      children,\n      errorElement,\n      resolve\n    } = this.props;\n    let promise = null;\n    let status = AwaitRenderStatus.pending;\n    if (!(resolve instanceof Promise)) {\n      // Didn't get a promise - provide as a resolved promise\n      status = AwaitRenderStatus.success;\n      promise = Promise.resolve();\n      Object.defineProperty(promise, \"_tracked\", {\n        get: () => true\n      });\n      Object.defineProperty(promise, \"_data\", {\n        get: () => resolve\n      });\n    } else if (this.state.error) {\n      // Caught a render error, provide it as a rejected promise\n      status = AwaitRenderStatus.error;\n      let renderError = this.state.error;\n      promise = Promise.reject().catch(() => {}); // Avoid unhandled rejection warnings\n      Object.defineProperty(promise, \"_tracked\", {\n        get: () => true\n      });\n      Object.defineProperty(promise, \"_error\", {\n        get: () => renderError\n      });\n    } else if (resolve._tracked) {\n      // Already tracked promise - check contents\n      promise = resolve;\n      status = promise._error !== undefined ? AwaitRenderStatus.error : promise._data !== undefined ? AwaitRenderStatus.success : AwaitRenderStatus.pending;\n    } else {\n      // Raw (untracked) promise - track it\n      status = AwaitRenderStatus.pending;\n      Object.defineProperty(resolve, \"_tracked\", {\n        get: () => true\n      });\n      promise = resolve.then(data => Object.defineProperty(resolve, \"_data\", {\n        get: () => data\n      }), error => Object.defineProperty(resolve, \"_error\", {\n        get: () => error\n      }));\n    }\n    if (status === AwaitRenderStatus.error && promise._error instanceof AbortedDeferredError) {\n      // Freeze the UI by throwing a never resolved promise\n      throw neverSettledPromise;\n    }\n    if (status === AwaitRenderStatus.error && !errorElement) {\n      // No errorElement, throw to the nearest route-level error boundary\n      throw promise._error;\n    }\n    if (status === AwaitRenderStatus.error) {\n      // Render via our errorElement\n      return /*#__PURE__*/React.createElement(AwaitContext.Provider, {\n        value: promise,\n        children: errorElement\n      });\n    }\n    if (status === AwaitRenderStatus.success) {\n      // Render children with resolved value\n      return /*#__PURE__*/React.createElement(AwaitContext.Provider, {\n        value: promise,\n        children: children\n      });\n    }\n\n    // Throw to the suspense boundary\n    throw promise;\n  }\n}\n\n/**\n * @private\n * Indirection to leverage useAsyncValue for a render-prop API on <Await>\n */\nfunction ResolveAwait(_ref8) {\n  let {\n    children\n  } = _ref8;\n  let data = useAsyncValue();\n  let toRender = typeof children === \"function\" ? children(data) : children;\n  return /*#__PURE__*/React.createElement(React.Fragment, null, toRender);\n}\n\n///////////////////////////////////////////////////////////////////////////////\n// UTILS\n///////////////////////////////////////////////////////////////////////////////\n\n/**\n * Creates a route config from a React \"children\" object, which is usually\n * either a `<Route>` element or an array of them. Used internally by\n * `<Routes>` to create a route config from its children.\n *\n * @see https://reactrouter.com/utils/create-routes-from-children\n */\nfunction createRoutesFromChildren(children, parentPath) {\n  if (parentPath === void 0) {\n    parentPath = [];\n  }\n  let routes = [];\n  React.Children.forEach(children, (element, index) => {\n    if (! /*#__PURE__*/React.isValidElement(element)) {\n      // Ignore non-elements. This allows people to more easily inline\n      // conditionals in their route config.\n      return;\n    }\n    let treePath = [...parentPath, index];\n    if (element.type === React.Fragment) {\n      // Transparently support React.Fragment and its children.\n      routes.push.apply(routes, createRoutesFromChildren(element.props.children, treePath));\n      return;\n    }\n    !(element.type === Route) ? process.env.NODE_ENV !== \"production\" ? 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>\") : UNSAFE_invariant(false) : void 0;\n    !(!element.props.index || !element.props.children) ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"An index route cannot have child routes.\") : UNSAFE_invariant(false) : void 0;\n    let route = {\n      id: element.props.id || treePath.join(\"-\"),\n      caseSensitive: element.props.caseSensitive,\n      element: element.props.element,\n      Component: element.props.Component,\n      index: element.props.index,\n      path: element.props.path,\n      loader: element.props.loader,\n      action: element.props.action,\n      errorElement: element.props.errorElement,\n      ErrorBoundary: element.props.ErrorBoundary,\n      hasErrorBoundary: element.props.ErrorBoundary != null || element.props.errorElement != null,\n      shouldRevalidate: element.props.shouldRevalidate,\n      handle: element.props.handle,\n      lazy: element.props.lazy\n    };\n    if (element.props.children) {\n      route.children = createRoutesFromChildren(element.props.children, treePath);\n    }\n    routes.push(route);\n  });\n  return routes;\n}\n\n/**\n * Renders the result of `matchRoutes()` into a React element.\n */\nfunction renderMatches(matches) {\n  return _renderMatches(matches);\n}\n\nfunction mapRouteProperties(route) {\n  let updates = {\n    // Note: this check also occurs in createRoutesFromChildren so update\n    // there if you change this -- please and thank you!\n    hasErrorBoundary: route.ErrorBoundary != null || route.errorElement != null\n  };\n  if (route.Component) {\n    if (process.env.NODE_ENV !== \"production\") {\n      if (route.element) {\n        process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(false, \"You should not include both `Component` and `element` on your route - \" + \"`Component` will be used.\") : void 0;\n      }\n    }\n    Object.assign(updates, {\n      element: /*#__PURE__*/React.createElement(route.Component),\n      Component: undefined\n    });\n  }\n  if (route.ErrorBoundary) {\n    if (process.env.NODE_ENV !== \"production\") {\n      if (route.errorElement) {\n        process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(false, \"You should not include both `ErrorBoundary` and `errorElement` on your route - \" + \"`ErrorBoundary` will be used.\") : void 0;\n      }\n    }\n    Object.assign(updates, {\n      errorElement: /*#__PURE__*/React.createElement(route.ErrorBoundary),\n      ErrorBoundary: undefined\n    });\n  }\n  return updates;\n}\nfunction createMemoryRouter(routes, opts) {\n  return createRouter({\n    basename: opts == null ? void 0 : opts.basename,\n    future: _extends({}, opts == null ? void 0 : opts.future, {\n      v7_prependBasename: true\n    }),\n    history: createMemoryHistory({\n      initialEntries: opts == null ? void 0 : opts.initialEntries,\n      initialIndex: opts == null ? void 0 : opts.initialIndex\n    }),\n    hydrationData: opts == null ? void 0 : opts.hydrationData,\n    routes,\n    mapRouteProperties\n  }).initialize();\n}\n\nexport { Await, MemoryRouter, Navigate, Outlet, Route, Router, RouterProvider, Routes, DataRouterContext as UNSAFE_DataRouterContext, DataRouterStateContext as UNSAFE_DataRouterStateContext, LocationContext as UNSAFE_LocationContext, NavigationContext as UNSAFE_NavigationContext, RouteContext as UNSAFE_RouteContext, mapRouteProperties as UNSAFE_mapRouteProperties, useRouteId as UNSAFE_useRouteId, useRoutesImpl as UNSAFE_useRoutesImpl, createMemoryRouter, createRoutesFromChildren, createRoutesFromChildren as createRoutesFromElements, renderMatches, useBlocker as unstable_useBlocker, useActionData, useAsyncError, useAsyncValue, useHref, useInRouterContext, useLoaderData, useLocation, useMatch, useMatches, useNavigate, useNavigation, useNavigationType, useOutlet, useOutletContext, useParams, useResolvedPath, useRevalidator, useRouteError, useRouteLoaderData, useRoutes };\n//# sourceMappingURL=index.js.map\n"],"names":["React","UNSAFE_invariant","joinPaths","matchPath","UNSAFE_getPathContributingMatches","UNSAFE_warning","resolveTo","parsePath","matchRoutes","Action","stripBasename","IDLE_BLOCKER","isRouteErrorResponse","createMemoryHistory","AbortedDeferredError","createRouter","NavigationType","createPath","defer","generatePath","json","redirect","redirectDocument","resolvePath","_extends","Object","assign","bind","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","DataRouterContext","createContext","process","displayName","DataRouterStateContext","AwaitContext","NavigationContext","LocationContext","RouteContext","outlet","matches","isDataRoute","RouteErrorContext","useHref","to","_temp","relative","useInRouterContext","basename","navigator","useContext","hash","pathname","search","useResolvedPath","joinedPathname","createHref","useLocation","location","useNavigationType","navigationType","useMatch","pattern","useMemo","navigateEffectWarning","useIsomorphicLayoutEffect","cb","isStatic","static","useLayoutEffect","useNavigate","useNavigateStable","useNavigateUnstable","dataRouterContext","locationPathname","routePathnamesJson","JSON","stringify","map","match","pathnameBase","activeRef","useRef","current","navigate","useCallback","options","go","path","parse","replace","push","state","OutletContext","useOutletContext","useOutlet","context","createElement","Provider","value","useParams","routeMatch","params","_temp2","useRoutes","routes","locationArg","useRoutesImpl","dataRouterState","parentMatches","parentParams","parentPathname","parentPathnameBase","parentRoute","route","parentPath","warningOnce","endsWith","locationFromContext","_parsedLocationArg$pa","parsedLocationArg","startsWith","remainingPathname","slice","element","undefined","Component","renderedMatches","_renderMatches","encodeLocation","Pop","DefaultErrorComponent","error","useRouteError","message","status","statusText","Error","stack","lightgrey","preStyles","padding","backgroundColor","codeStyles","devInfo","console","Fragment","style","fontStyle","defaultErrorElement","RenderErrorBoundary","constructor","props","revalidation","getDerivedStateFromError","getDerivedStateFromProps","componentDidCatch","errorInfo","render","routeContext","children","component","RenderedRoute","_ref","staticContext","errorElement","ErrorBoundary","_deepestRenderedBoundaryId","id","_dataRouterState2","_dataRouterState","errors","errorIndex","findIndex","m","keys","join","Math","min","reduceRight","index","concat","getChildren","DataRouterHook","DataRouterStateHook","getDataRouterConsoleError","hookName","useDataRouterContext","ctx","useDataRouterState","useRouteContext","useCurrentRouteId","thisRoute","useRouteId","UseRouteId","useNavigation","UseNavigation","navigation","useRevalidator","UseRevalidator","revalidate","router","useMatches","loaderData","UseMatches","data","handle","useLoaderData","UseLoaderData","routeId","useRouteLoaderData","UseRouteLoaderData","useActionData","UseActionData","values","actionData","_state$errors","UseRouteError","useAsyncValue","_data","useAsyncError","_error","blockerId","useBlocker","shouldBlock","UseBlocker","blockerKey","setBlockerKey","useState","blockerFunction","arg","currentLocation","nextLocation","historyAction","useEffect","String","deleteBlocker","getBlocker","blockers","has","get","UseNavigateStable","fromRouteId","alreadyWarned","cond","START_TRANSITION","startTransitionImpl","RouterProvider","fallbackElement","future","setStateImpl","v7_startTransition","setState","newState","subscribe","n","opts","preventScrollReset","Router","initialized","DataRoutes","_ref2","MemoryRouter","_ref3","initialEntries","initialIndex","historyRef","v5Compat","history","action","listen","Navigate","_ref4","jsonPath","Outlet","Route","_props","_ref5","basenameProp","locationProp","staticProp","navigationContext","locationContext","trailingPathname","Routes","_ref6","createRoutesFromChildren","Await","_ref7","resolve","AwaitErrorBoundary","ResolveAwait","AwaitRenderStatus","neverSettledPromise","Promise","promise","pending","success","defineProperty","renderError","reject","catch","_tracked","then","_ref8","toRender","Children","forEach","isValidElement","treePath","type","name","caseSensitive","loader","hasErrorBoundary","shouldRevalidate","lazy","renderMatches","mapRouteProperties","updates","createMemoryRouter","v7_prependBasename","hydrationData","initialize","UNSAFE_DataRouterContext","UNSAFE_DataRouterStateContext","UNSAFE_LocationContext","UNSAFE_NavigationContext","UNSAFE_RouteContext","UNSAFE_mapRouteProperties","UNSAFE_useRouteId","UNSAFE_useRoutesImpl","createRoutesFromElements","unstable_useBlocker"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/react-router/dist/index.js\n");
/***/ })
};
;