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
149 KiB
JavaScript
25 lines
149 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-dom";
|
|
exports.ids = ["vendor-chunks/react-router-dom"];
|
|
exports.modules = {
|
|
|
|
/***/ "(ssr)/./node_modules/react-router-dom/dist/index.js":
|
|
/*!*****************************************************!*\
|
|
!*** ./node_modules/react-router-dom/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 */ react_router__WEBPACK_IMPORTED_MODULE_1__.AbortedDeferredError),\n/* harmony export */ Await: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.Await),\n/* harmony export */ BrowserRouter: () => (/* binding */ BrowserRouter),\n/* harmony export */ Form: () => (/* binding */ Form),\n/* harmony export */ HashRouter: () => (/* binding */ HashRouter),\n/* harmony export */ Link: () => (/* binding */ Link),\n/* harmony export */ MemoryRouter: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.MemoryRouter),\n/* harmony export */ NavLink: () => (/* binding */ NavLink),\n/* harmony export */ Navigate: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.Navigate),\n/* harmony export */ NavigationType: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.Action),\n/* harmony export */ Outlet: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.Outlet),\n/* harmony export */ Route: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.Route),\n/* harmony export */ Router: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.Router),\n/* harmony export */ RouterProvider: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.RouterProvider),\n/* harmony export */ Routes: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.Routes),\n/* harmony export */ ScrollRestoration: () => (/* binding */ ScrollRestoration),\n/* harmony export */ UNSAFE_DataRouterContext: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_DataRouterContext),\n/* harmony export */ UNSAFE_DataRouterStateContext: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_DataRouterStateContext),\n/* harmony export */ UNSAFE_LocationContext: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_LocationContext),\n/* harmony export */ UNSAFE_NavigationContext: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_NavigationContext),\n/* harmony export */ UNSAFE_RouteContext: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_RouteContext),\n/* harmony export */ UNSAFE_useRouteId: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_useRouteId),\n/* harmony export */ UNSAFE_useScrollRestoration: () => (/* binding */ useScrollRestoration),\n/* harmony export */ createBrowserRouter: () => (/* binding */ createBrowserRouter),\n/* harmony export */ createHashRouter: () => (/* binding */ createHashRouter),\n/* harmony export */ createMemoryRouter: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.createMemoryRouter),\n/* harmony export */ createPath: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.createPath),\n/* harmony export */ createRoutesFromChildren: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.createRoutesFromChildren),\n/* harmony export */ createRoutesFromElements: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.createRoutesFromElements),\n/* harmony export */ createSearchParams: () => (/* binding */ createSearchParams),\n/* harmony export */ defer: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.defer),\n/* harmony export */ generatePath: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.generatePath),\n/* harmony export */ isRouteErrorResponse: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.isRouteErrorResponse),\n/* harmony export */ json: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.json),\n/* harmony export */ matchPath: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.matchPath),\n/* harmony export */ matchRoutes: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.matchRoutes),\n/* harmony export */ parsePath: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.parsePath),\n/* harmony export */ redirect: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.redirect),\n/* harmony export */ redirectDocument: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.redirectDocument),\n/* harmony export */ renderMatches: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.renderMatches),\n/* harmony export */ resolvePath: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_1__.resolvePath),\n/* harmony export */ unstable_HistoryRouter: () => (/* binding */ HistoryRouter),\n/* harmony export */ unstable_useBlocker: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.unstable_useBlocker),\n/* harmony export */ unstable_usePrompt: () => (/* binding */ usePrompt),\n/* harmony export */ useActionData: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useActionData),\n/* harmony export */ useAsyncError: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useAsyncError),\n/* harmony export */ useAsyncValue: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useAsyncValue),\n/* harmony export */ useBeforeUnload: () => (/* binding */ useBeforeUnload),\n/* harmony export */ useFetcher: () => (/* binding */ useFetcher),\n/* harmony export */ useFetchers: () => (/* binding */ useFetchers),\n/* harmony export */ useFormAction: () => (/* binding */ useFormAction),\n/* harmony export */ useHref: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useHref),\n/* harmony export */ useInRouterContext: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useInRouterContext),\n/* harmony export */ useLinkClickHandler: () => (/* binding */ useLinkClickHandler),\n/* harmony export */ useLoaderData: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useLoaderData),\n/* harmony export */ useLocation: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useLocation),\n/* harmony export */ useMatch: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useMatch),\n/* harmony export */ useMatches: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useMatches),\n/* harmony export */ useNavigate: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useNavigate),\n/* harmony export */ useNavigation: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useNavigation),\n/* harmony export */ useNavigationType: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useNavigationType),\n/* harmony export */ useOutlet: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useOutlet),\n/* harmony export */ useOutletContext: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useOutletContext),\n/* harmony export */ useParams: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useParams),\n/* harmony export */ useResolvedPath: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useResolvedPath),\n/* harmony export */ useRevalidator: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useRevalidator),\n/* harmony export */ useRouteError: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useRouteError),\n/* harmony export */ useRouteLoaderData: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useRouteLoaderData),\n/* harmony export */ useRoutes: () => (/* reexport safe */ react_router__WEBPACK_IMPORTED_MODULE_2__.useRoutes),\n/* harmony export */ useSearchParams: () => (/* binding */ useSearchParams),\n/* harmony export */ useSubmit: () => (/* binding */ useSubmit)\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 react_router__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! react-router */ \"(ssr)/./node_modules/react-router/dist/index.js\");\n/* harmony import */ var react_router__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @remix-run/router */ \"(ssr)/./node_modules/@remix-run/router/dist/router.js\");\n/**\n * React Router DOM 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\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}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n if (source == null) return {};\n var target = {};\n var sourceKeys = Object.keys(source);\n var key, i;\n for(i = 0; i < sourceKeys.length; i++){\n key = sourceKeys[i];\n if (excluded.indexOf(key) >= 0) continue;\n target[key] = source[key];\n }\n return target;\n}\nconst defaultMethod = \"get\";\nconst defaultEncType = \"application/x-www-form-urlencoded\";\nfunction isHtmlElement(object) {\n return object != null && typeof object.tagName === \"string\";\n}\nfunction isButtonElement(object) {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"button\";\n}\nfunction isFormElement(object) {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"form\";\n}\nfunction isInputElement(object) {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"input\";\n}\nfunction isModifiedEvent(event) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\nfunction shouldProcessLinkClick(event, target) {\n return event.button === 0 && // Ignore everything but left clicks\n (!target || target === \"_self\") && // Let browser handle \"target=_blank\" etc.\n !isModifiedEvent(event) // Ignore clicks with modifier keys\n ;\n}\n/**\n * Creates a URLSearchParams object using the given initializer.\n *\n * This is identical to `new URLSearchParams(init)` except it also\n * supports arrays as values in the object form of the initializer\n * instead of just strings. This is convenient when you need multiple\n * values for a given key, but don't want to use an array initializer.\n *\n * For example, instead of:\n *\n * let searchParams = new URLSearchParams([\n * ['sort', 'name'],\n * ['sort', 'price']\n * ]);\n *\n * you can do:\n *\n * let searchParams = createSearchParams({\n * sort: ['name', 'price']\n * });\n */ function createSearchParams(init) {\n if (init === void 0) {\n init = \"\";\n }\n return new URLSearchParams(typeof init === \"string\" || Array.isArray(init) || init instanceof URLSearchParams ? init : Object.keys(init).reduce((memo, key)=>{\n let value = init[key];\n return memo.concat(Array.isArray(value) ? value.map((v)=>[\n key,\n v\n ]) : [\n [\n key,\n value\n ]\n ]);\n }, []));\n}\nfunction getSearchParamsForLocation(locationSearch, defaultSearchParams) {\n let searchParams = createSearchParams(locationSearch);\n if (defaultSearchParams) {\n // Use `defaultSearchParams.forEach(...)` here instead of iterating of\n // `defaultSearchParams.keys()` to work-around a bug in Firefox related to\n // web extensions. Relevant Bugzilla tickets:\n // https://bugzilla.mozilla.org/show_bug.cgi?id=1414602\n // https://bugzilla.mozilla.org/show_bug.cgi?id=1023984\n defaultSearchParams.forEach((_, key)=>{\n if (!searchParams.has(key)) {\n defaultSearchParams.getAll(key).forEach((value)=>{\n searchParams.append(key, value);\n });\n }\n });\n }\n return searchParams;\n}\n// One-time check for submitter support\nlet _formDataSupportsSubmitter = null;\nfunction isFormDataSubmitterSupported() {\n if (_formDataSupportsSubmitter === null) {\n try {\n new FormData(document.createElement(\"form\"), // @ts-expect-error if FormData supports the submitter parameter, this will throw\n 0);\n _formDataSupportsSubmitter = false;\n } catch (e) {\n _formDataSupportsSubmitter = true;\n }\n }\n return _formDataSupportsSubmitter;\n}\nconst supportedFormEncTypes = new Set([\n \"application/x-www-form-urlencoded\",\n \"multipart/form-data\",\n \"text/plain\"\n]);\nfunction getFormEncType(encType) {\n if (encType != null && !supportedFormEncTypes.has(encType)) {\n true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(false, '\"' + encType + '\" is not a valid `encType` for `<Form>`/`<fetcher.Form>` ' + ('and will default to \"' + defaultEncType + '\"')) : 0;\n return null;\n }\n return encType;\n}\nfunction getFormSubmissionInfo(target, basename) {\n let method;\n let action;\n let encType;\n let formData;\n let body;\n if (isFormElement(target)) {\n // When grabbing the action from the element, it will have had the basename\n // prefixed to ensure non-JS scenarios work, so strip it since we'll\n // re-prefix in the router\n let attr = target.getAttribute(\"action\");\n action = attr ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.stripBasename)(attr, basename) : null;\n method = target.getAttribute(\"method\") || defaultMethod;\n encType = getFormEncType(target.getAttribute(\"enctype\")) || defaultEncType;\n formData = new FormData(target);\n } else if (isButtonElement(target) || isInputElement(target) && (target.type === \"submit\" || target.type === \"image\")) {\n let form = target.form;\n if (form == null) {\n throw new Error('Cannot submit a <button> or <input type=\"submit\"> without a <form>');\n }\n // <button>/<input type=\"submit\"> may override attributes of <form>\n // When grabbing the action from the element, it will have had the basename\n // prefixed to ensure non-JS scenarios work, so strip it since we'll\n // re-prefix in the router\n let attr = target.getAttribute(\"formaction\") || form.getAttribute(\"action\");\n action = attr ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.stripBasename)(attr, basename) : null;\n method = target.getAttribute(\"formmethod\") || form.getAttribute(\"method\") || defaultMethod;\n encType = getFormEncType(target.getAttribute(\"formenctype\")) || getFormEncType(form.getAttribute(\"enctype\")) || defaultEncType;\n // Build a FormData object populated from a form and submitter\n formData = new FormData(form, target);\n // If this browser doesn't support the `FormData(el, submitter)` format,\n // then tack on the submitter value at the end. This is a lightweight\n // solution that is not 100% spec compliant. For complete support in older\n // browsers, consider using the `formdata-submitter-polyfill` package\n if (!isFormDataSubmitterSupported()) {\n let { name, type, value } = target;\n if (type === \"image\") {\n let prefix = name ? name + \".\" : \"\";\n formData.append(prefix + \"x\", \"0\");\n formData.append(prefix + \"y\", \"0\");\n } else if (name) {\n formData.append(name, value);\n }\n }\n } else if (isHtmlElement(target)) {\n throw new Error(\"Cannot submit element that is not <form>, <button>, or \" + '<input type=\"submit|image\">');\n } else {\n method = defaultMethod;\n action = null;\n encType = defaultEncType;\n body = target;\n }\n // Send body for <Form encType=\"text/plain\" so we encode it into text\n if (formData && encType === \"text/plain\") {\n body = formData;\n formData = undefined;\n }\n return {\n action,\n method: method.toLowerCase(),\n encType,\n formData,\n body\n };\n}\nconst _excluded = [\n \"onClick\",\n \"relative\",\n \"reloadDocument\",\n \"replace\",\n \"state\",\n \"target\",\n \"to\",\n \"preventScrollReset\"\n], _excluded2 = [\n \"aria-current\",\n \"caseSensitive\",\n \"className\",\n \"end\",\n \"style\",\n \"to\",\n \"children\"\n], _excluded3 = [\n \"reloadDocument\",\n \"replace\",\n \"state\",\n \"method\",\n \"action\",\n \"onSubmit\",\n \"submit\",\n \"relative\",\n \"preventScrollReset\"\n];\nfunction createBrowserRouter(routes, opts) {\n return (0,react_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,react_router__WEBPACK_IMPORTED_MODULE_1__.createBrowserHistory)({\n window: opts == null ? void 0 : opts.window\n }),\n hydrationData: (opts == null ? void 0 : opts.hydrationData) || parseHydrationData(),\n routes,\n mapRouteProperties: react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_mapRouteProperties\n }).initialize();\n}\nfunction createHashRouter(routes, opts) {\n return (0,react_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,react_router__WEBPACK_IMPORTED_MODULE_1__.createHashHistory)({\n window: opts == null ? void 0 : opts.window\n }),\n hydrationData: (opts == null ? void 0 : opts.hydrationData) || parseHydrationData(),\n routes,\n mapRouteProperties: react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_mapRouteProperties\n }).initialize();\n}\nfunction parseHydrationData() {\n var _window;\n let state = (_window = window) == null ? void 0 : _window.__staticRouterHydrationData;\n if (state && state.errors) {\n state = _extends({}, state, {\n errors: deserializeErrors(state.errors)\n });\n }\n return state;\n}\nfunction deserializeErrors(errors) {\n if (!errors) return null;\n let entries = Object.entries(errors);\n let serialized = {};\n for (let [key, val] of entries){\n // Hey you! If you change this, please change the corresponding logic in\n // serializeErrors in react-router-dom/server.tsx :)\n if (val && val.__type === \"RouteErrorResponse\") {\n serialized[key] = new react_router__WEBPACK_IMPORTED_MODULE_1__.ErrorResponse(val.status, val.statusText, val.data, val.internal === true);\n } else if (val && val.__type === \"Error\") {\n // Attempt to reconstruct the right type of Error (i.e., ReferenceError)\n if (val.__subType) {\n let ErrorConstructor = window[val.__subType];\n if (typeof ErrorConstructor === \"function\") {\n try {\n // @ts-expect-error\n let error = new ErrorConstructor(val.message);\n // Wipe away the client-side stack trace. Nothing to fill it in with\n // because we don't serialize SSR stack traces for security reasons\n error.stack = \"\";\n serialized[key] = error;\n } catch (e) {\n // no-op - fall through and create a normal Error\n }\n }\n }\n if (serialized[key] == null) {\n let error = new Error(val.message);\n // Wipe away the client-side stack trace. Nothing to fill it in with\n // because we don't serialize SSR stack traces for security reasons\n error.stack = \"\";\n serialized[key] = error;\n }\n } else {\n serialized[key] = val;\n }\n }\n return serialized;\n}\n//#endregion\n////////////////////////////////////////////////////////////////////////////////\n//#region Components\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 * A `<Router>` for use in web browsers. Provides the cleanest URLs.\n */ function BrowserRouter(_ref) {\n let { basename, children, future, window: window1 } = _ref;\n let historyRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef();\n if (historyRef.current == null) {\n historyRef.current = (0,react_router__WEBPACK_IMPORTED_MODULE_1__.createBrowserHistory)({\n window: window1,\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(react_router__WEBPACK_IMPORTED_MODULE_2__.Router, {\n basename: basename,\n children: children,\n location: state.location,\n navigationType: state.action,\n navigator: history\n });\n}\n/**\n * A `<Router>` for use in web browsers. Stores the location in the hash\n * portion of the URL so it is not sent to the server.\n */ function HashRouter(_ref2) {\n let { basename, children, future, window: window1 } = _ref2;\n let historyRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef();\n if (historyRef.current == null) {\n historyRef.current = (0,react_router__WEBPACK_IMPORTED_MODULE_1__.createHashHistory)({\n window: window1,\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(react_router__WEBPACK_IMPORTED_MODULE_2__.Router, {\n basename: basename,\n children: children,\n location: state.location,\n navigationType: state.action,\n navigator: history\n });\n}\n/**\n * A `<Router>` that accepts a pre-instantiated history object. It's important\n * to note that using your own history object is highly discouraged and may add\n * two versions of the history library to your bundles unless you use the same\n * version of the history library that React Router uses internally.\n */ function HistoryRouter(_ref3) {\n let { basename, children, future, history } = _ref3;\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(react_router__WEBPACK_IMPORTED_MODULE_2__.Router, {\n basename: basename,\n children: children,\n location: state.location,\n navigationType: state.action,\n navigator: history\n });\n}\nif (true) {\n HistoryRouter.displayName = \"unstable_HistoryRouter\";\n}\nconst isBrowser = false && 0;\nconst ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\n/**\n * The public API for rendering a history-aware <a>.\n */ const Link = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(function LinkWithRef(_ref4, ref) {\n let { onClick, relative, reloadDocument, replace, state, target, to, preventScrollReset } = _ref4, rest = _objectWithoutPropertiesLoose(_ref4, _excluded);\n let { basename } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_NavigationContext);\n // Rendered into <a href> for absolute URLs\n let absoluteHref;\n let isExternal = false;\n if (typeof to === \"string\" && ABSOLUTE_URL_REGEX.test(to)) {\n // Render the absolute href server- and client-side\n absoluteHref = to;\n // Only check for external origins client-side\n if (isBrowser) {\n try {\n let currentUrl = new URL(window.location.href);\n let targetUrl = to.startsWith(\"//\") ? new URL(currentUrl.protocol + to) : new URL(to);\n let path = (0,react_router__WEBPACK_IMPORTED_MODULE_1__.stripBasename)(targetUrl.pathname, basename);\n if (targetUrl.origin === currentUrl.origin && path != null) {\n // Strip the protocol/origin/basename for same-origin absolute URLs\n to = path + targetUrl.search + targetUrl.hash;\n } else {\n isExternal = true;\n }\n } catch (e) {\n // We can't do external URL detection without a valid URL\n true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(false, '<Link to=\"' + to + '\"> contains an invalid URL which will probably break ' + \"when clicked - please update to a valid URL path.\") : 0;\n }\n }\n }\n // Rendered into <a href> for relative URLs\n let href = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useHref)(to, {\n relative\n });\n let internalOnClick = useLinkClickHandler(to, {\n replace,\n state,\n target,\n preventScrollReset,\n relative\n });\n function handleClick(event) {\n if (onClick) onClick(event);\n if (!event.defaultPrevented) {\n internalOnClick(event);\n }\n }\n return(/*#__PURE__*/ // eslint-disable-next-line jsx-a11y/anchor-has-content\n react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"a\", _extends({}, rest, {\n href: absoluteHref || href,\n onClick: isExternal || reloadDocument ? onClick : handleClick,\n ref: ref,\n target: target\n })));\n});\nif (true) {\n Link.displayName = \"Link\";\n}\n/**\n * A <Link> wrapper that knows if it's \"active\" or not.\n */ const NavLink = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.forwardRef(function NavLinkWithRef(_ref5, ref) {\n let { \"aria-current\": ariaCurrentProp = \"page\", caseSensitive = false, className: classNameProp = \"\", end = false, style: styleProp, to, children } = _ref5, rest = _objectWithoutPropertiesLoose(_ref5, _excluded2);\n let path = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useResolvedPath)(to, {\n relative: rest.relative\n });\n let location = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useLocation)();\n let routerState = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_DataRouterStateContext);\n let { navigator } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_NavigationContext);\n let toPathname = navigator.encodeLocation ? navigator.encodeLocation(path).pathname : path.pathname;\n let locationPathname = location.pathname;\n let nextLocationPathname = routerState && routerState.navigation && routerState.navigation.location ? routerState.navigation.location.pathname : null;\n if (!caseSensitive) {\n locationPathname = locationPathname.toLowerCase();\n nextLocationPathname = nextLocationPathname ? nextLocationPathname.toLowerCase() : null;\n toPathname = toPathname.toLowerCase();\n }\n let isActive = locationPathname === toPathname || !end && locationPathname.startsWith(toPathname) && locationPathname.charAt(toPathname.length) === \"/\";\n let isPending = nextLocationPathname != null && (nextLocationPathname === toPathname || !end && nextLocationPathname.startsWith(toPathname) && nextLocationPathname.charAt(toPathname.length) === \"/\");\n let ariaCurrent = isActive ? ariaCurrentProp : undefined;\n let className;\n if (typeof classNameProp === \"function\") {\n className = classNameProp({\n isActive,\n isPending\n });\n } else {\n // If the className prop is not a function, we use a default `active`\n // class for <NavLink />s that are active. In v5 `active` was the default\n // value for `activeClassName`, but we are removing that API and can still\n // use the old default behavior for a cleaner upgrade path and keep the\n // simple styling rules working as they currently do.\n className = [\n classNameProp,\n isActive ? \"active\" : null,\n isPending ? \"pending\" : null\n ].filter(Boolean).join(\" \");\n }\n let style = typeof styleProp === \"function\" ? styleProp({\n isActive,\n isPending\n }) : styleProp;\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(Link, _extends({}, rest, {\n \"aria-current\": ariaCurrent,\n className: className,\n ref: ref,\n style: style,\n to: to\n }), typeof children === \"function\" ? children({\n isActive,\n isPending\n }) : children);\n});\nif (true) {\n NavLink.displayName = \"NavLink\";\n}\n/**\n * A `@remix-run/router`-aware `<form>`. It behaves like a normal form except\n * that the interaction with the server is with `fetch` instead of new document\n * requests, allowing components to add nicer UX to the page as the form is\n * submitted and returns with data.\n */ const Form = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.forwardRef((props, ref)=>{\n let submit = useSubmit();\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(FormImpl, _extends({}, props, {\n submit: submit,\n ref: ref\n }));\n});\nif (true) {\n Form.displayName = \"Form\";\n}\nconst FormImpl = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.forwardRef((_ref6, forwardedRef)=>{\n let { reloadDocument, replace, state, method = defaultMethod, action, onSubmit, submit, relative, preventScrollReset } = _ref6, props = _objectWithoutPropertiesLoose(_ref6, _excluded3);\n let formMethod = method.toLowerCase() === \"get\" ? \"get\" : \"post\";\n let formAction = useFormAction(action, {\n relative\n });\n let submitHandler = (event)=>{\n onSubmit && onSubmit(event);\n if (event.defaultPrevented) return;\n event.preventDefault();\n let submitter = event.nativeEvent.submitter;\n let submitMethod = (submitter == null ? void 0 : submitter.getAttribute(\"formmethod\")) || method;\n submit(submitter || event.currentTarget, {\n method: submitMethod,\n replace,\n state,\n relative,\n preventScrollReset\n });\n };\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(\"form\", _extends({\n ref: forwardedRef,\n method: formMethod,\n action: formAction,\n onSubmit: reloadDocument ? onSubmit : submitHandler\n }, props));\n});\nif (true) {\n FormImpl.displayName = \"FormImpl\";\n}\n/**\n * This component will emulate the browser's scroll restoration on location\n * changes.\n */ function ScrollRestoration(_ref7) {\n let { getKey, storageKey } = _ref7;\n useScrollRestoration({\n getKey,\n storageKey\n });\n return null;\n}\nif (true) {\n ScrollRestoration.displayName = \"ScrollRestoration\";\n}\n//#endregion\n////////////////////////////////////////////////////////////////////////////////\n//#region Hooks\n////////////////////////////////////////////////////////////////////////////////\nvar DataRouterHook;\n(function(DataRouterHook) {\n DataRouterHook[\"UseScrollRestoration\"] = \"useScrollRestoration\";\n DataRouterHook[\"UseSubmit\"] = \"useSubmit\";\n DataRouterHook[\"UseSubmitFetcher\"] = \"useSubmitFetcher\";\n DataRouterHook[\"UseFetcher\"] = \"useFetcher\";\n})(DataRouterHook || (DataRouterHook = {}));\nvar DataRouterStateHook;\n(function(DataRouterStateHook) {\n DataRouterStateHook[\"UseFetchers\"] = \"useFetchers\";\n DataRouterStateHook[\"UseScrollRestoration\"] = \"useScrollRestoration\";\n})(DataRouterStateHook || (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(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_DataRouterContext);\n !ctx ? true ? (0,react_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(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_DataRouterStateContext);\n !state ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, getDataRouterConsoleError(hookName)) : 0 : void 0;\n return state;\n}\n/**\n * Handles the click behavior for router `<Link>` components. This is useful if\n * you need to create custom `<Link>` components with the same click behavior we\n * use in our exported `<Link>`.\n */ function useLinkClickHandler(to, _temp) {\n let { target, replace: replaceProp, state, preventScrollReset, relative } = _temp === void 0 ? {} : _temp;\n let navigate = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useNavigate)();\n let location = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useLocation)();\n let path = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useResolvedPath)(to, {\n relative\n });\n return react__WEBPACK_IMPORTED_MODULE_0__.useCallback((event)=>{\n if (shouldProcessLinkClick(event, target)) {\n event.preventDefault();\n // If the URL hasn't changed, a regular <a> will do a replace instead of\n // a push, so do the same here unless the replace prop is explicitly set\n let replace = replaceProp !== undefined ? replaceProp : (0,react_router__WEBPACK_IMPORTED_MODULE_1__.createPath)(location) === (0,react_router__WEBPACK_IMPORTED_MODULE_1__.createPath)(path);\n navigate(to, {\n replace,\n state,\n preventScrollReset,\n relative\n });\n }\n }, [\n location,\n navigate,\n path,\n replaceProp,\n state,\n target,\n to,\n preventScrollReset,\n relative\n ]);\n}\n/**\n * A convenient wrapper for reading and writing search parameters via the\n * URLSearchParams interface.\n */ function useSearchParams(defaultInit) {\n true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_warning)(typeof URLSearchParams !== \"undefined\", \"You cannot use the `useSearchParams` hook in a browser that does not \" + \"support the URLSearchParams API. If you need to support Internet \" + \"Explorer 11, we recommend you load a polyfill such as \" + \"https://github.com/ungap/url-search-params\\n\\n\" + \"If you're unsure how to load polyfills, we recommend you check out \" + \"https://polyfill.io/v3/ which provides some recommendations about how \" + \"to load polyfills only for users that need them, instead of for every \" + \"user.\") : 0;\n let defaultSearchParamsRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(createSearchParams(defaultInit));\n let hasSetSearchParamsRef = react__WEBPACK_IMPORTED_MODULE_0__.useRef(false);\n let location = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useLocation)();\n let searchParams = react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>// Only merge in the defaults if we haven't yet called setSearchParams.\n // Once we call that we want those to take precedence, otherwise you can't\n // remove a param with setSearchParams({}) if it has an initial value\n getSearchParamsForLocation(location.search, hasSetSearchParamsRef.current ? null : defaultSearchParamsRef.current), [\n location.search\n ]);\n let navigate = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useNavigate)();\n let setSearchParams = react__WEBPACK_IMPORTED_MODULE_0__.useCallback((nextInit, navigateOptions)=>{\n const newSearchParams = createSearchParams(typeof nextInit === \"function\" ? nextInit(searchParams) : nextInit);\n hasSetSearchParamsRef.current = true;\n navigate(\"?\" + newSearchParams, navigateOptions);\n }, [\n navigate,\n searchParams\n ]);\n return [\n searchParams,\n setSearchParams\n ];\n}\nfunction validateClientSideSubmission() {\n if (typeof document === \"undefined\") {\n throw new Error(\"You are calling submit during the server render. \" + \"Try calling submit within a `useEffect` or callback instead.\");\n }\n}\n/**\n * Returns a function that may be used to programmatically submit a form (or\n * some arbitrary data) to the server.\n */ function useSubmit() {\n let { router } = useDataRouterContext(DataRouterHook.UseSubmit);\n let { basename } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_NavigationContext);\n let currentRouteId = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_useRouteId)();\n return react__WEBPACK_IMPORTED_MODULE_0__.useCallback(function(target, options) {\n if (options === void 0) {\n options = {};\n }\n validateClientSideSubmission();\n let { action, method, encType, formData, body } = getFormSubmissionInfo(target, basename);\n router.navigate(options.action || action, {\n preventScrollReset: options.preventScrollReset,\n formData,\n body,\n formMethod: options.method || method,\n formEncType: options.encType || encType,\n replace: options.replace,\n state: options.state,\n fromRouteId: currentRouteId\n });\n }, [\n router,\n basename,\n currentRouteId\n ]);\n}\n/**\n * Returns the implementation for fetcher.submit\n */ function useSubmitFetcher(fetcherKey, fetcherRouteId) {\n let { router } = useDataRouterContext(DataRouterHook.UseSubmitFetcher);\n let { basename } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_NavigationContext);\n return react__WEBPACK_IMPORTED_MODULE_0__.useCallback(function(target, options) {\n if (options === void 0) {\n options = {};\n }\n validateClientSideSubmission();\n let { action, method, encType, formData, body } = getFormSubmissionInfo(target, basename);\n !(fetcherRouteId != null) ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"No routeId available for useFetcher()\") : 0 : void 0;\n router.fetch(fetcherKey, fetcherRouteId, options.action || action, {\n preventScrollReset: options.preventScrollReset,\n formData,\n body,\n formMethod: options.method || method,\n formEncType: options.encType || encType\n });\n }, [\n router,\n basename,\n fetcherKey,\n fetcherRouteId\n ]);\n}\n// v7: Eventually we should deprecate this entirely in favor of using the\n// router method directly?\nfunction useFormAction(action, _temp2) {\n let { relative } = _temp2 === void 0 ? {} : _temp2;\n let { basename } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_NavigationContext);\n let routeContext = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_RouteContext);\n !routeContext ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"useFormAction must be used inside a RouteContext\") : 0 : void 0;\n let [match] = routeContext.matches.slice(-1);\n // Shallow clone path so we can modify it below, otherwise we modify the\n // object referenced by useMemo inside useResolvedPath\n let path = _extends({}, (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useResolvedPath)(action ? action : \".\", {\n relative\n }));\n // Previously we set the default action to \".\". The problem with this is that\n // `useResolvedPath(\".\")` excludes search params of the resolved URL. This is\n // the intended behavior of when \".\" is specifically provided as\n // the form action, but inconsistent w/ browsers when the action is omitted.\n // https://github.com/remix-run/remix/issues/927\n let location = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useLocation)();\n if (action == null) {\n // Safe to write to this directly here since if action was undefined, we\n // would have called useResolvedPath(\".\") which will never include a search\n path.search = location.search;\n // When grabbing search params from the URL, remove the automatically\n // inserted ?index param so we match the useResolvedPath search behavior\n // which would not include ?index\n if (match.route.index) {\n let params = new URLSearchParams(path.search);\n params.delete(\"index\");\n path.search = params.toString() ? \"?\" + params.toString() : \"\";\n }\n }\n if ((!action || action === \".\") && match.route.index) {\n path.search = path.search ? path.search.replace(/^\\?/, \"?index&\") : \"?index\";\n }\n // If we're operating within a basename, prepend it to the pathname prior\n // to creating the form action. If this is a root navigation, then just use\n // the raw basename which allows the basename to have full control over the\n // presence of a trailing slash on root actions\n if (basename !== \"/\") {\n path.pathname = path.pathname === \"/\" ? basename : (0,react_router__WEBPACK_IMPORTED_MODULE_1__.joinPaths)([\n basename,\n path.pathname\n ]);\n }\n return (0,react_router__WEBPACK_IMPORTED_MODULE_1__.createPath)(path);\n}\nfunction createFetcherForm(fetcherKey, routeId) {\n let FetcherForm = /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.forwardRef((props, ref)=>{\n let submit = useSubmitFetcher(fetcherKey, routeId);\n return /*#__PURE__*/ react__WEBPACK_IMPORTED_MODULE_0__.createElement(FormImpl, _extends({}, props, {\n ref: ref,\n submit: submit\n }));\n });\n if (true) {\n FetcherForm.displayName = \"fetcher.Form\";\n }\n return FetcherForm;\n}\nlet fetcherId = 0;\n/**\n * Interacts with route loaders and actions without causing a navigation. Great\n * for any interaction that stays on the same page.\n */ function useFetcher() {\n var _route$matches;\n let { router } = useDataRouterContext(DataRouterHook.UseFetcher);\n let route = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_RouteContext);\n !route ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"useFetcher must be used inside a RouteContext\") : 0 : void 0;\n let routeId = (_route$matches = route.matches[route.matches.length - 1]) == null ? void 0 : _route$matches.route.id;\n !(routeId != null) ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, 'useFetcher can only be used on routes that contain a unique \"id\"') : 0 : void 0;\n let [fetcherKey] = react__WEBPACK_IMPORTED_MODULE_0__.useState(()=>String(++fetcherId));\n let [Form] = react__WEBPACK_IMPORTED_MODULE_0__.useState(()=>{\n !routeId ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"No routeId available for fetcher.Form()\") : 0 : void 0;\n return createFetcherForm(fetcherKey, routeId);\n });\n let [load] = react__WEBPACK_IMPORTED_MODULE_0__.useState(()=>(href)=>{\n !router ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"No router available for fetcher.load()\") : 0 : void 0;\n !routeId ? true ? (0,react_router__WEBPACK_IMPORTED_MODULE_1__.UNSAFE_invariant)(false, \"No routeId available for fetcher.load()\") : 0 : void 0;\n router.fetch(fetcherKey, routeId, href);\n });\n let submit = useSubmitFetcher(fetcherKey, routeId);\n let fetcher = router.getFetcher(fetcherKey);\n let fetcherWithComponents = react__WEBPACK_IMPORTED_MODULE_0__.useMemo(()=>_extends({\n Form,\n submit,\n load\n }, fetcher), [\n fetcher,\n Form,\n submit,\n load\n ]);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n // Is this busted when the React team gets real weird and calls effects\n // twice on mount? We really just need to garbage collect here when this\n // fetcher is no longer around.\n return ()=>{\n if (!router) {\n console.warn(\"No router available to clean up from useFetcher()\");\n return;\n }\n router.deleteFetcher(fetcherKey);\n };\n }, [\n router,\n fetcherKey\n ]);\n return fetcherWithComponents;\n}\n/**\n * Provides all fetchers currently on the page. Useful for layouts and parent\n * routes that need to provide pending/optimistic UI regarding the fetch.\n */ function useFetchers() {\n let state = useDataRouterState(DataRouterStateHook.UseFetchers);\n return [\n ...state.fetchers.values()\n ];\n}\nconst SCROLL_RESTORATION_STORAGE_KEY = \"react-router-scroll-positions\";\nlet savedScrollPositions = {};\n/**\n * When rendered inside a RouterProvider, will restore scroll positions on navigations\n */ function useScrollRestoration(_temp3) {\n let { getKey, storageKey } = _temp3 === void 0 ? {} : _temp3;\n let { router } = useDataRouterContext(DataRouterHook.UseScrollRestoration);\n let { restoreScrollPosition, preventScrollReset } = useDataRouterState(DataRouterStateHook.UseScrollRestoration);\n let { basename } = react__WEBPACK_IMPORTED_MODULE_0__.useContext(react_router__WEBPACK_IMPORTED_MODULE_2__.UNSAFE_NavigationContext);\n let location = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useLocation)();\n let matches = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useMatches)();\n let navigation = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.useNavigation)();\n // Trigger manual scroll restoration while we're active\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n window.history.scrollRestoration = \"manual\";\n return ()=>{\n window.history.scrollRestoration = \"auto\";\n };\n }, []);\n // Save positions on pagehide\n usePageHide(react__WEBPACK_IMPORTED_MODULE_0__.useCallback(()=>{\n if (navigation.state === \"idle\") {\n let key = (getKey ? getKey(location, matches) : null) || location.key;\n savedScrollPositions[key] = window.scrollY;\n }\n sessionStorage.setItem(storageKey || SCROLL_RESTORATION_STORAGE_KEY, JSON.stringify(savedScrollPositions));\n window.history.scrollRestoration = \"auto\";\n }, [\n storageKey,\n getKey,\n navigation.state,\n location,\n matches\n ]));\n // Read in any saved scroll locations\n if (typeof document !== \"undefined\") {\n // eslint-disable-next-line react-hooks/rules-of-hooks\n react__WEBPACK_IMPORTED_MODULE_0__.useLayoutEffect(()=>{\n try {\n let sessionPositions = sessionStorage.getItem(storageKey || SCROLL_RESTORATION_STORAGE_KEY);\n if (sessionPositions) {\n savedScrollPositions = JSON.parse(sessionPositions);\n }\n } catch (e) {\n // no-op, use default empty object\n }\n }, [\n storageKey\n ]);\n // Enable scroll restoration in the router\n // eslint-disable-next-line react-hooks/rules-of-hooks\n react__WEBPACK_IMPORTED_MODULE_0__.useLayoutEffect(()=>{\n let getKeyWithoutBasename = getKey && basename !== \"/\" ? (location, matches)=>getKey(_extends({}, location, {\n pathname: (0,react_router__WEBPACK_IMPORTED_MODULE_1__.stripBasename)(location.pathname, basename) || location.pathname\n }), matches) : getKey;\n let disableScrollRestoration = router == null ? void 0 : router.enableScrollRestoration(savedScrollPositions, ()=>window.scrollY, getKeyWithoutBasename);\n return ()=>disableScrollRestoration && disableScrollRestoration();\n }, [\n router,\n basename,\n getKey\n ]);\n // Restore scrolling when state.restoreScrollPosition changes\n // eslint-disable-next-line react-hooks/rules-of-hooks\n react__WEBPACK_IMPORTED_MODULE_0__.useLayoutEffect(()=>{\n // Explicit false means don't do anything (used for submissions)\n if (restoreScrollPosition === false) {\n return;\n }\n // been here before, scroll to it\n if (typeof restoreScrollPosition === \"number\") {\n window.scrollTo(0, restoreScrollPosition);\n return;\n }\n // try to scroll to the hash\n if (location.hash) {\n let el = document.getElementById(decodeURIComponent(location.hash.slice(1)));\n if (el) {\n el.scrollIntoView();\n return;\n }\n }\n // Don't reset if this navigation opted out\n if (preventScrollReset === true) {\n return;\n }\n // otherwise go to the top on new locations\n window.scrollTo(0, 0);\n }, [\n location,\n restoreScrollPosition,\n preventScrollReset\n ]);\n }\n}\n/**\n * Setup a callback to be fired on the window's `beforeunload` event. This is\n * useful for saving some data to `window.localStorage` just before the page\n * refreshes.\n *\n * Note: The `callback` argument should be a function created with\n * `React.useCallback()`.\n */ function useBeforeUnload(callback, options) {\n let { capture } = options || {};\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n let opts = capture != null ? {\n capture\n } : undefined;\n window.addEventListener(\"beforeunload\", callback, opts);\n return ()=>{\n window.removeEventListener(\"beforeunload\", callback, opts);\n };\n }, [\n callback,\n capture\n ]);\n}\n/**\n * Setup a callback to be fired on the window's `pagehide` event. This is\n * useful for saving some data to `window.localStorage` just before the page\n * refreshes. This event is better supported than beforeunload across browsers.\n *\n * Note: The `callback` argument should be a function created with\n * `React.useCallback()`.\n */ function usePageHide(callback, options) {\n let { capture } = options || {};\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n let opts = capture != null ? {\n capture\n } : undefined;\n window.addEventListener(\"pagehide\", callback, opts);\n return ()=>{\n window.removeEventListener(\"pagehide\", callback, opts);\n };\n }, [\n callback,\n capture\n ]);\n}\n/**\n * Wrapper around useBlocker to show a window.confirm prompt to users instead\n * of building a custom UI with useBlocker.\n *\n * Warning: This has *a lot of rough edges* and behaves very differently (and\n * very incorrectly in some cases) across browsers if user click addition\n * back/forward navigations while the confirm is open. Use at your own risk.\n */ function usePrompt(_ref8) {\n let { when, message } = _ref8;\n let blocker = (0,react_router__WEBPACK_IMPORTED_MODULE_2__.unstable_useBlocker)(when);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n if (blocker.state === \"blocked\") {\n let proceed = window.confirm(message);\n if (proceed) {\n // This timeout is needed to avoid a weird \"race\" on POP navigations\n // between the `window.history` revert navigation and the result of\n // `window.confirm`\n setTimeout(blocker.proceed, 0);\n } else {\n blocker.reset();\n }\n }\n }, [\n blocker,\n message\n ]);\n react__WEBPACK_IMPORTED_MODULE_0__.useEffect(()=>{\n if (blocker.state === \"blocked\" && !when) {\n blocker.reset();\n }\n }, [\n blocker,\n when\n ]);\n}\n//#endregion\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-dom/dist/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/react-router-dom/dist/index.js?03a6"],"sourcesContent":["/**\n * React Router DOM 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_mapRouteProperties, Router, UNSAFE_NavigationContext, useHref, useResolvedPath, useLocation, UNSAFE_DataRouterStateContext, useNavigate, createPath, UNSAFE_useRouteId, UNSAFE_RouteContext, useMatches, useNavigation, unstable_useBlocker, UNSAFE_DataRouterContext } from 'react-router';\nexport { AbortedDeferredError, Await, MemoryRouter, Navigate, NavigationType, Outlet, Route, Router, RouterProvider, Routes, UNSAFE_DataRouterContext, UNSAFE_DataRouterStateContext, UNSAFE_LocationContext, UNSAFE_NavigationContext, UNSAFE_RouteContext, UNSAFE_useRouteId, createMemoryRouter, createPath, createRoutesFromChildren, createRoutesFromElements, defer, generatePath, isRouteErrorResponse, json, matchPath, matchRoutes, parsePath, redirect, redirectDocument, renderMatches, resolvePath, unstable_useBlocker, useActionData, useAsyncError, useAsyncValue, useHref, useInRouterContext, useLoaderData, useLocation, useMatch, useMatches, useNavigate, useNavigation, useNavigationType, useOutlet, useOutletContext, useParams, useResolvedPath, useRevalidator, useRouteError, useRouteLoaderData, useRoutes } from 'react-router';\nimport { stripBasename, UNSAFE_warning, createRouter, createBrowserHistory, createHashHistory, ErrorResponse, UNSAFE_invariant, joinPaths } 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}\nfunction _objectWithoutPropertiesLoose(source, excluded) {\n  if (source == null) return {};\n  var target = {};\n  var sourceKeys = Object.keys(source);\n  var key, i;\n  for (i = 0; i < sourceKeys.length; i++) {\n    key = sourceKeys[i];\n    if (excluded.indexOf(key) >= 0) continue;\n    target[key] = source[key];\n  }\n  return target;\n}\n\nconst defaultMethod = \"get\";\nconst defaultEncType = \"application/x-www-form-urlencoded\";\nfunction isHtmlElement(object) {\n  return object != null && typeof object.tagName === \"string\";\n}\nfunction isButtonElement(object) {\n  return isHtmlElement(object) && object.tagName.toLowerCase() === \"button\";\n}\nfunction isFormElement(object) {\n  return isHtmlElement(object) && object.tagName.toLowerCase() === \"form\";\n}\nfunction isInputElement(object) {\n  return isHtmlElement(object) && object.tagName.toLowerCase() === \"input\";\n}\nfunction isModifiedEvent(event) {\n  return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\nfunction shouldProcessLinkClick(event, target) {\n  return event.button === 0 && (\n  // Ignore everything but left clicks\n  !target || target === \"_self\") &&\n  // Let browser handle \"target=_blank\" etc.\n  !isModifiedEvent(event) // Ignore clicks with modifier keys\n  ;\n}\n/**\n * Creates a URLSearchParams object using the given initializer.\n *\n * This is identical to `new URLSearchParams(init)` except it also\n * supports arrays as values in the object form of the initializer\n * instead of just strings. This is convenient when you need multiple\n * values for a given key, but don't want to use an array initializer.\n *\n * For example, instead of:\n *\n *   let searchParams = new URLSearchParams([\n *     ['sort', 'name'],\n *     ['sort', 'price']\n *   ]);\n *\n * you can do:\n *\n *   let searchParams = createSearchParams({\n *     sort: ['name', 'price']\n *   });\n */\nfunction createSearchParams(init) {\n  if (init === void 0) {\n    init = \"\";\n  }\n  return new URLSearchParams(typeof init === \"string\" || Array.isArray(init) || init instanceof URLSearchParams ? init : Object.keys(init).reduce((memo, key) => {\n    let value = init[key];\n    return memo.concat(Array.isArray(value) ? value.map(v => [key, v]) : [[key, value]]);\n  }, []));\n}\nfunction getSearchParamsForLocation(locationSearch, defaultSearchParams) {\n  let searchParams = createSearchParams(locationSearch);\n  if (defaultSearchParams) {\n    // Use `defaultSearchParams.forEach(...)` here instead of iterating of\n    // `defaultSearchParams.keys()` to work-around a bug in Firefox related to\n    // web extensions. Relevant Bugzilla tickets:\n    // https://bugzilla.mozilla.org/show_bug.cgi?id=1414602\n    // https://bugzilla.mozilla.org/show_bug.cgi?id=1023984\n    defaultSearchParams.forEach((_, key) => {\n      if (!searchParams.has(key)) {\n        defaultSearchParams.getAll(key).forEach(value => {\n          searchParams.append(key, value);\n        });\n      }\n    });\n  }\n  return searchParams;\n}\n// One-time check for submitter support\nlet _formDataSupportsSubmitter = null;\nfunction isFormDataSubmitterSupported() {\n  if (_formDataSupportsSubmitter === null) {\n    try {\n      new FormData(document.createElement(\"form\"),\n      // @ts-expect-error if FormData supports the submitter parameter, this will throw\n      0);\n      _formDataSupportsSubmitter = false;\n    } catch (e) {\n      _formDataSupportsSubmitter = true;\n    }\n  }\n  return _formDataSupportsSubmitter;\n}\nconst supportedFormEncTypes = new Set([\"application/x-www-form-urlencoded\", \"multipart/form-data\", \"text/plain\"]);\nfunction getFormEncType(encType) {\n  if (encType != null && !supportedFormEncTypes.has(encType)) {\n    process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(false, \"\\\"\" + encType + \"\\\" is not a valid `encType` for `<Form>`/`<fetcher.Form>` \" + (\"and will default to \\\"\" + defaultEncType + \"\\\"\")) : void 0;\n    return null;\n  }\n  return encType;\n}\nfunction getFormSubmissionInfo(target, basename) {\n  let method;\n  let action;\n  let encType;\n  let formData;\n  let body;\n  if (isFormElement(target)) {\n    // When grabbing the action from the element, it will have had the basename\n    // prefixed to ensure non-JS scenarios work, so strip it since we'll\n    // re-prefix in the router\n    let attr = target.getAttribute(\"action\");\n    action = attr ? stripBasename(attr, basename) : null;\n    method = target.getAttribute(\"method\") || defaultMethod;\n    encType = getFormEncType(target.getAttribute(\"enctype\")) || defaultEncType;\n    formData = new FormData(target);\n  } else if (isButtonElement(target) || isInputElement(target) && (target.type === \"submit\" || target.type === \"image\")) {\n    let form = target.form;\n    if (form == null) {\n      throw new Error(\"Cannot submit a <button> or <input type=\\\"submit\\\"> without a <form>\");\n    }\n    // <button>/<input type=\"submit\"> may override attributes of <form>\n    // When grabbing the action from the element, it will have had the basename\n    // prefixed to ensure non-JS scenarios work, so strip it since we'll\n    // re-prefix in the router\n    let attr = target.getAttribute(\"formaction\") || form.getAttribute(\"action\");\n    action = attr ? stripBasename(attr, basename) : null;\n    method = target.getAttribute(\"formmethod\") || form.getAttribute(\"method\") || defaultMethod;\n    encType = getFormEncType(target.getAttribute(\"formenctype\")) || getFormEncType(form.getAttribute(\"enctype\")) || defaultEncType;\n    // Build a FormData object populated from a form and submitter\n    formData = new FormData(form, target);\n    // If this browser doesn't support the `FormData(el, submitter)` format,\n    // then tack on the submitter value at the end.  This is a lightweight\n    // solution that is not 100% spec compliant.  For complete support in older\n    // browsers, consider using the `formdata-submitter-polyfill` package\n    if (!isFormDataSubmitterSupported()) {\n      let {\n        name,\n        type,\n        value\n      } = target;\n      if (type === \"image\") {\n        let prefix = name ? name + \".\" : \"\";\n        formData.append(prefix + \"x\", \"0\");\n        formData.append(prefix + \"y\", \"0\");\n      } else if (name) {\n        formData.append(name, value);\n      }\n    }\n  } else if (isHtmlElement(target)) {\n    throw new Error(\"Cannot submit element that is not <form>, <button>, or \" + \"<input type=\\\"submit|image\\\">\");\n  } else {\n    method = defaultMethod;\n    action = null;\n    encType = defaultEncType;\n    body = target;\n  }\n  // Send body for <Form encType=\"text/plain\" so we encode it into text\n  if (formData && encType === \"text/plain\") {\n    body = formData;\n    formData = undefined;\n  }\n  return {\n    action,\n    method: method.toLowerCase(),\n    encType,\n    formData,\n    body\n  };\n}\n\nconst _excluded = [\"onClick\", \"relative\", \"reloadDocument\", \"replace\", \"state\", \"target\", \"to\", \"preventScrollReset\"],\n  _excluded2 = [\"aria-current\", \"caseSensitive\", \"className\", \"end\", \"style\", \"to\", \"children\"],\n  _excluded3 = [\"reloadDocument\", \"replace\", \"state\", \"method\", \"action\", \"onSubmit\", \"submit\", \"relative\", \"preventScrollReset\"];\nfunction createBrowserRouter(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: createBrowserHistory({\n      window: opts == null ? void 0 : opts.window\n    }),\n    hydrationData: (opts == null ? void 0 : opts.hydrationData) || parseHydrationData(),\n    routes,\n    mapRouteProperties: UNSAFE_mapRouteProperties\n  }).initialize();\n}\nfunction createHashRouter(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: createHashHistory({\n      window: opts == null ? void 0 : opts.window\n    }),\n    hydrationData: (opts == null ? void 0 : opts.hydrationData) || parseHydrationData(),\n    routes,\n    mapRouteProperties: UNSAFE_mapRouteProperties\n  }).initialize();\n}\nfunction parseHydrationData() {\n  var _window;\n  let state = (_window = window) == null ? void 0 : _window.__staticRouterHydrationData;\n  if (state && state.errors) {\n    state = _extends({}, state, {\n      errors: deserializeErrors(state.errors)\n    });\n  }\n  return state;\n}\nfunction deserializeErrors(errors) {\n  if (!errors) return null;\n  let entries = Object.entries(errors);\n  let serialized = {};\n  for (let [key, val] of entries) {\n    // Hey you!  If you change this, please change the corresponding logic in\n    // serializeErrors in react-router-dom/server.tsx :)\n    if (val && val.__type === \"RouteErrorResponse\") {\n      serialized[key] = new ErrorResponse(val.status, val.statusText, val.data, val.internal === true);\n    } else if (val && val.__type === \"Error\") {\n      // Attempt to reconstruct the right type of Error (i.e., ReferenceError)\n      if (val.__subType) {\n        let ErrorConstructor = window[val.__subType];\n        if (typeof ErrorConstructor === \"function\") {\n          try {\n            // @ts-expect-error\n            let error = new ErrorConstructor(val.message);\n            // Wipe away the client-side stack trace.  Nothing to fill it in with\n            // because we don't serialize SSR stack traces for security reasons\n            error.stack = \"\";\n            serialized[key] = error;\n          } catch (e) {\n            // no-op - fall through and create a normal Error\n          }\n        }\n      }\n      if (serialized[key] == null) {\n        let error = new Error(val.message);\n        // Wipe away the client-side stack trace.  Nothing to fill it in with\n        // because we don't serialize SSR stack traces for security reasons\n        error.stack = \"\";\n        serialized[key] = error;\n      }\n    } else {\n      serialized[key] = val;\n    }\n  }\n  return serialized;\n}\n//#endregion\n////////////////////////////////////////////////////////////////////////////////\n//#region Components\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 * A `<Router>` for use in web browsers. Provides the cleanest URLs.\n */\nfunction BrowserRouter(_ref) {\n  let {\n    basename,\n    children,\n    future,\n    window\n  } = _ref;\n  let historyRef = React.useRef();\n  if (historyRef.current == null) {\n    historyRef.current = createBrowserHistory({\n      window,\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 * A `<Router>` for use in web browsers. Stores the location in the hash\n * portion of the URL so it is not sent to the server.\n */\nfunction HashRouter(_ref2) {\n  let {\n    basename,\n    children,\n    future,\n    window\n  } = _ref2;\n  let historyRef = React.useRef();\n  if (historyRef.current == null) {\n    historyRef.current = createHashHistory({\n      window,\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 * A `<Router>` that accepts a pre-instantiated history object. It's important\n * to note that using your own history object is highly discouraged and may add\n * two versions of the history library to your bundles unless you use the same\n * version of the history library that React Router uses internally.\n */\nfunction HistoryRouter(_ref3) {\n  let {\n    basename,\n    children,\n    future,\n    history\n  } = _ref3;\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}\nif (process.env.NODE_ENV !== \"production\") {\n  HistoryRouter.displayName = \"unstable_HistoryRouter\";\n}\nconst isBrowser = typeof window !== \"undefined\" && typeof window.document !== \"undefined\" && typeof window.document.createElement !== \"undefined\";\nconst ABSOLUTE_URL_REGEX = /^(?:[a-z][a-z0-9+.-]*:|\\/\\/)/i;\n/**\n * The public API for rendering a history-aware <a>.\n */\nconst Link = /*#__PURE__*/React.forwardRef(function LinkWithRef(_ref4, ref) {\n  let {\n      onClick,\n      relative,\n      reloadDocument,\n      replace,\n      state,\n      target,\n      to,\n      preventScrollReset\n    } = _ref4,\n    rest = _objectWithoutPropertiesLoose(_ref4, _excluded);\n  let {\n    basename\n  } = React.useContext(UNSAFE_NavigationContext);\n  // Rendered into <a href> for absolute URLs\n  let absoluteHref;\n  let isExternal = false;\n  if (typeof to === \"string\" && ABSOLUTE_URL_REGEX.test(to)) {\n    // Render the absolute href server- and client-side\n    absoluteHref = to;\n    // Only check for external origins client-side\n    if (isBrowser) {\n      try {\n        let currentUrl = new URL(window.location.href);\n        let targetUrl = to.startsWith(\"//\") ? new URL(currentUrl.protocol + to) : new URL(to);\n        let path = stripBasename(targetUrl.pathname, basename);\n        if (targetUrl.origin === currentUrl.origin && path != null) {\n          // Strip the protocol/origin/basename for same-origin absolute URLs\n          to = path + targetUrl.search + targetUrl.hash;\n        } else {\n          isExternal = true;\n        }\n      } catch (e) {\n        // We can't do external URL detection without a valid URL\n        process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(false, \"<Link to=\\\"\" + to + \"\\\"> contains an invalid URL which will probably break \" + \"when clicked - please update to a valid URL path.\") : void 0;\n      }\n    }\n  }\n  // Rendered into <a href> for relative URLs\n  let href = useHref(to, {\n    relative\n  });\n  let internalOnClick = useLinkClickHandler(to, {\n    replace,\n    state,\n    target,\n    preventScrollReset,\n    relative\n  });\n  function handleClick(event) {\n    if (onClick) onClick(event);\n    if (!event.defaultPrevented) {\n      internalOnClick(event);\n    }\n  }\n  return (\n    /*#__PURE__*/\n    // eslint-disable-next-line jsx-a11y/anchor-has-content\n    React.createElement(\"a\", _extends({}, rest, {\n      href: absoluteHref || href,\n      onClick: isExternal || reloadDocument ? onClick : handleClick,\n      ref: ref,\n      target: target\n    }))\n  );\n});\nif (process.env.NODE_ENV !== \"production\") {\n  Link.displayName = \"Link\";\n}\n/**\n * A <Link> wrapper that knows if it's \"active\" or not.\n */\nconst NavLink = /*#__PURE__*/React.forwardRef(function NavLinkWithRef(_ref5, ref) {\n  let {\n      \"aria-current\": ariaCurrentProp = \"page\",\n      caseSensitive = false,\n      className: classNameProp = \"\",\n      end = false,\n      style: styleProp,\n      to,\n      children\n    } = _ref5,\n    rest = _objectWithoutPropertiesLoose(_ref5, _excluded2);\n  let path = useResolvedPath(to, {\n    relative: rest.relative\n  });\n  let location = useLocation();\n  let routerState = React.useContext(UNSAFE_DataRouterStateContext);\n  let {\n    navigator\n  } = React.useContext(UNSAFE_NavigationContext);\n  let toPathname = navigator.encodeLocation ? navigator.encodeLocation(path).pathname : path.pathname;\n  let locationPathname = location.pathname;\n  let nextLocationPathname = routerState && routerState.navigation && routerState.navigation.location ? routerState.navigation.location.pathname : null;\n  if (!caseSensitive) {\n    locationPathname = locationPathname.toLowerCase();\n    nextLocationPathname = nextLocationPathname ? nextLocationPathname.toLowerCase() : null;\n    toPathname = toPathname.toLowerCase();\n  }\n  let isActive = locationPathname === toPathname || !end && locationPathname.startsWith(toPathname) && locationPathname.charAt(toPathname.length) === \"/\";\n  let isPending = nextLocationPathname != null && (nextLocationPathname === toPathname || !end && nextLocationPathname.startsWith(toPathname) && nextLocationPathname.charAt(toPathname.length) === \"/\");\n  let ariaCurrent = isActive ? ariaCurrentProp : undefined;\n  let className;\n  if (typeof classNameProp === \"function\") {\n    className = classNameProp({\n      isActive,\n      isPending\n    });\n  } else {\n    // If the className prop is not a function, we use a default `active`\n    // class for <NavLink />s that are active. In v5 `active` was the default\n    // value for `activeClassName`, but we are removing that API and can still\n    // use the old default behavior for a cleaner upgrade path and keep the\n    // simple styling rules working as they currently do.\n    className = [classNameProp, isActive ? \"active\" : null, isPending ? \"pending\" : null].filter(Boolean).join(\" \");\n  }\n  let style = typeof styleProp === \"function\" ? styleProp({\n    isActive,\n    isPending\n  }) : styleProp;\n  return /*#__PURE__*/React.createElement(Link, _extends({}, rest, {\n    \"aria-current\": ariaCurrent,\n    className: className,\n    ref: ref,\n    style: style,\n    to: to\n  }), typeof children === \"function\" ? children({\n    isActive,\n    isPending\n  }) : children);\n});\nif (process.env.NODE_ENV !== \"production\") {\n  NavLink.displayName = \"NavLink\";\n}\n/**\n * A `@remix-run/router`-aware `<form>`. It behaves like a normal form except\n * that the interaction with the server is with `fetch` instead of new document\n * requests, allowing components to add nicer UX to the page as the form is\n * submitted and returns with data.\n */\nconst Form = /*#__PURE__*/React.forwardRef((props, ref) => {\n  let submit = useSubmit();\n  return /*#__PURE__*/React.createElement(FormImpl, _extends({}, props, {\n    submit: submit,\n    ref: ref\n  }));\n});\nif (process.env.NODE_ENV !== \"production\") {\n  Form.displayName = \"Form\";\n}\nconst FormImpl = /*#__PURE__*/React.forwardRef((_ref6, forwardedRef) => {\n  let {\n      reloadDocument,\n      replace,\n      state,\n      method = defaultMethod,\n      action,\n      onSubmit,\n      submit,\n      relative,\n      preventScrollReset\n    } = _ref6,\n    props = _objectWithoutPropertiesLoose(_ref6, _excluded3);\n  let formMethod = method.toLowerCase() === \"get\" ? \"get\" : \"post\";\n  let formAction = useFormAction(action, {\n    relative\n  });\n  let submitHandler = event => {\n    onSubmit && onSubmit(event);\n    if (event.defaultPrevented) return;\n    event.preventDefault();\n    let submitter = event.nativeEvent.submitter;\n    let submitMethod = (submitter == null ? void 0 : submitter.getAttribute(\"formmethod\")) || method;\n    submit(submitter || event.currentTarget, {\n      method: submitMethod,\n      replace,\n      state,\n      relative,\n      preventScrollReset\n    });\n  };\n  return /*#__PURE__*/React.createElement(\"form\", _extends({\n    ref: forwardedRef,\n    method: formMethod,\n    action: formAction,\n    onSubmit: reloadDocument ? onSubmit : submitHandler\n  }, props));\n});\nif (process.env.NODE_ENV !== \"production\") {\n  FormImpl.displayName = \"FormImpl\";\n}\n/**\n * This component will emulate the browser's scroll restoration on location\n * changes.\n */\nfunction ScrollRestoration(_ref7) {\n  let {\n    getKey,\n    storageKey\n  } = _ref7;\n  useScrollRestoration({\n    getKey,\n    storageKey\n  });\n  return null;\n}\nif (process.env.NODE_ENV !== \"production\") {\n  ScrollRestoration.displayName = \"ScrollRestoration\";\n}\n//#endregion\n////////////////////////////////////////////////////////////////////////////////\n//#region Hooks\n////////////////////////////////////////////////////////////////////////////////\nvar DataRouterHook;\n(function (DataRouterHook) {\n  DataRouterHook[\"UseScrollRestoration\"] = \"useScrollRestoration\";\n  DataRouterHook[\"UseSubmit\"] = \"useSubmit\";\n  DataRouterHook[\"UseSubmitFetcher\"] = \"useSubmitFetcher\";\n  DataRouterHook[\"UseFetcher\"] = \"useFetcher\";\n})(DataRouterHook || (DataRouterHook = {}));\nvar DataRouterStateHook;\n(function (DataRouterStateHook) {\n  DataRouterStateHook[\"UseFetchers\"] = \"useFetchers\";\n  DataRouterStateHook[\"UseScrollRestoration\"] = \"useScrollRestoration\";\n})(DataRouterStateHook || (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(UNSAFE_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(UNSAFE_DataRouterStateContext);\n  !state ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, getDataRouterConsoleError(hookName)) : UNSAFE_invariant(false) : void 0;\n  return state;\n}\n/**\n * Handles the click behavior for router `<Link>` components. This is useful if\n * you need to create custom `<Link>` components with the same click behavior we\n * use in our exported `<Link>`.\n */\nfunction useLinkClickHandler(to, _temp) {\n  let {\n    target,\n    replace: replaceProp,\n    state,\n    preventScrollReset,\n    relative\n  } = _temp === void 0 ? {} : _temp;\n  let navigate = useNavigate();\n  let location = useLocation();\n  let path = useResolvedPath(to, {\n    relative\n  });\n  return React.useCallback(event => {\n    if (shouldProcessLinkClick(event, target)) {\n      event.preventDefault();\n      // If the URL hasn't changed, a regular <a> will do a replace instead of\n      // a push, so do the same here unless the replace prop is explicitly set\n      let replace = replaceProp !== undefined ? replaceProp : createPath(location) === createPath(path);\n      navigate(to, {\n        replace,\n        state,\n        preventScrollReset,\n        relative\n      });\n    }\n  }, [location, navigate, path, replaceProp, state, target, to, preventScrollReset, relative]);\n}\n/**\n * A convenient wrapper for reading and writing search parameters via the\n * URLSearchParams interface.\n */\nfunction useSearchParams(defaultInit) {\n  process.env.NODE_ENV !== \"production\" ? UNSAFE_warning(typeof URLSearchParams !== \"undefined\", \"You cannot use the `useSearchParams` hook in a browser that does not \" + \"support the URLSearchParams API. If you need to support Internet \" + \"Explorer 11, we recommend you load a polyfill such as \" + \"https://github.com/ungap/url-search-params\\n\\n\" + \"If you're unsure how to load polyfills, we recommend you check out \" + \"https://polyfill.io/v3/ which provides some recommendations about how \" + \"to load polyfills only for users that need them, instead of for every \" + \"user.\") : void 0;\n  let defaultSearchParamsRef = React.useRef(createSearchParams(defaultInit));\n  let hasSetSearchParamsRef = React.useRef(false);\n  let location = useLocation();\n  let searchParams = React.useMemo(() =>\n  // Only merge in the defaults if we haven't yet called setSearchParams.\n  // Once we call that we want those to take precedence, otherwise you can't\n  // remove a param with setSearchParams({}) if it has an initial value\n  getSearchParamsForLocation(location.search, hasSetSearchParamsRef.current ? null : defaultSearchParamsRef.current), [location.search]);\n  let navigate = useNavigate();\n  let setSearchParams = React.useCallback((nextInit, navigateOptions) => {\n    const newSearchParams = createSearchParams(typeof nextInit === \"function\" ? nextInit(searchParams) : nextInit);\n    hasSetSearchParamsRef.current = true;\n    navigate(\"?\" + newSearchParams, navigateOptions);\n  }, [navigate, searchParams]);\n  return [searchParams, setSearchParams];\n}\nfunction validateClientSideSubmission() {\n  if (typeof document === \"undefined\") {\n    throw new Error(\"You are calling submit during the server render. \" + \"Try calling submit within a `useEffect` or callback instead.\");\n  }\n}\n/**\n * Returns a function that may be used to programmatically submit a form (or\n * some arbitrary data) to the server.\n */\nfunction useSubmit() {\n  let {\n    router\n  } = useDataRouterContext(DataRouterHook.UseSubmit);\n  let {\n    basename\n  } = React.useContext(UNSAFE_NavigationContext);\n  let currentRouteId = UNSAFE_useRouteId();\n  return React.useCallback(function (target, options) {\n    if (options === void 0) {\n      options = {};\n    }\n    validateClientSideSubmission();\n    let {\n      action,\n      method,\n      encType,\n      formData,\n      body\n    } = getFormSubmissionInfo(target, basename);\n    router.navigate(options.action || action, {\n      preventScrollReset: options.preventScrollReset,\n      formData,\n      body,\n      formMethod: options.method || method,\n      formEncType: options.encType || encType,\n      replace: options.replace,\n      state: options.state,\n      fromRouteId: currentRouteId\n    });\n  }, [router, basename, currentRouteId]);\n}\n/**\n * Returns the implementation for fetcher.submit\n */\nfunction useSubmitFetcher(fetcherKey, fetcherRouteId) {\n  let {\n    router\n  } = useDataRouterContext(DataRouterHook.UseSubmitFetcher);\n  let {\n    basename\n  } = React.useContext(UNSAFE_NavigationContext);\n  return React.useCallback(function (target, options) {\n    if (options === void 0) {\n      options = {};\n    }\n    validateClientSideSubmission();\n    let {\n      action,\n      method,\n      encType,\n      formData,\n      body\n    } = getFormSubmissionInfo(target, basename);\n    !(fetcherRouteId != null) ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"No routeId available for useFetcher()\") : UNSAFE_invariant(false) : void 0;\n    router.fetch(fetcherKey, fetcherRouteId, options.action || action, {\n      preventScrollReset: options.preventScrollReset,\n      formData,\n      body,\n      formMethod: options.method || method,\n      formEncType: options.encType || encType\n    });\n  }, [router, basename, fetcherKey, fetcherRouteId]);\n}\n// v7: Eventually we should deprecate this entirely in favor of using the\n// router method directly?\nfunction useFormAction(action, _temp2) {\n  let {\n    relative\n  } = _temp2 === void 0 ? {} : _temp2;\n  let {\n    basename\n  } = React.useContext(UNSAFE_NavigationContext);\n  let routeContext = React.useContext(UNSAFE_RouteContext);\n  !routeContext ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"useFormAction must be used inside a RouteContext\") : UNSAFE_invariant(false) : void 0;\n  let [match] = routeContext.matches.slice(-1);\n  // Shallow clone path so we can modify it below, otherwise we modify the\n  // object referenced by useMemo inside useResolvedPath\n  let path = _extends({}, useResolvedPath(action ? action : \".\", {\n    relative\n  }));\n  // Previously we set the default action to \".\". The problem with this is that\n  // `useResolvedPath(\".\")` excludes search params of the resolved URL. This is\n  // the intended behavior of when \".\" is specifically provided as\n  // the form action, but inconsistent w/ browsers when the action is omitted.\n  // https://github.com/remix-run/remix/issues/927\n  let location = useLocation();\n  if (action == null) {\n    // Safe to write to this directly here since if action was undefined, we\n    // would have called useResolvedPath(\".\") which will never include a search\n    path.search = location.search;\n    // When grabbing search params from the URL, remove the automatically\n    // inserted ?index param so we match the useResolvedPath search behavior\n    // which would not include ?index\n    if (match.route.index) {\n      let params = new URLSearchParams(path.search);\n      params.delete(\"index\");\n      path.search = params.toString() ? \"?\" + params.toString() : \"\";\n    }\n  }\n  if ((!action || action === \".\") && match.route.index) {\n    path.search = path.search ? path.search.replace(/^\\?/, \"?index&\") : \"?index\";\n  }\n  // If we're operating within a basename, prepend it to the pathname prior\n  // to creating the form action.  If this is a root navigation, then just use\n  // the raw basename which allows the basename to have full control over the\n  // presence of a trailing slash on root actions\n  if (basename !== \"/\") {\n    path.pathname = path.pathname === \"/\" ? basename : joinPaths([basename, path.pathname]);\n  }\n  return createPath(path);\n}\nfunction createFetcherForm(fetcherKey, routeId) {\n  let FetcherForm = /*#__PURE__*/React.forwardRef((props, ref) => {\n    let submit = useSubmitFetcher(fetcherKey, routeId);\n    return /*#__PURE__*/React.createElement(FormImpl, _extends({}, props, {\n      ref: ref,\n      submit: submit\n    }));\n  });\n  if (process.env.NODE_ENV !== \"production\") {\n    FetcherForm.displayName = \"fetcher.Form\";\n  }\n  return FetcherForm;\n}\nlet fetcherId = 0;\n/**\n * Interacts with route loaders and actions without causing a navigation. Great\n * for any interaction that stays on the same page.\n */\nfunction useFetcher() {\n  var _route$matches;\n  let {\n    router\n  } = useDataRouterContext(DataRouterHook.UseFetcher);\n  let route = React.useContext(UNSAFE_RouteContext);\n  !route ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"useFetcher must be used inside a RouteContext\") : UNSAFE_invariant(false) : void 0;\n  let routeId = (_route$matches = route.matches[route.matches.length - 1]) == null ? void 0 : _route$matches.route.id;\n  !(routeId != null) ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"useFetcher can only be used on routes that contain a unique \\\"id\\\"\") : UNSAFE_invariant(false) : void 0;\n  let [fetcherKey] = React.useState(() => String(++fetcherId));\n  let [Form] = React.useState(() => {\n    !routeId ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"No routeId available for fetcher.Form()\") : UNSAFE_invariant(false) : void 0;\n    return createFetcherForm(fetcherKey, routeId);\n  });\n  let [load] = React.useState(() => href => {\n    !router ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"No router available for fetcher.load()\") : UNSAFE_invariant(false) : void 0;\n    !routeId ? process.env.NODE_ENV !== \"production\" ? UNSAFE_invariant(false, \"No routeId available for fetcher.load()\") : UNSAFE_invariant(false) : void 0;\n    router.fetch(fetcherKey, routeId, href);\n  });\n  let submit = useSubmitFetcher(fetcherKey, routeId);\n  let fetcher = router.getFetcher(fetcherKey);\n  let fetcherWithComponents = React.useMemo(() => _extends({\n    Form,\n    submit,\n    load\n  }, fetcher), [fetcher, Form, submit, load]);\n  React.useEffect(() => {\n    // Is this busted when the React team gets real weird and calls effects\n    // twice on mount?  We really just need to garbage collect here when this\n    // fetcher is no longer around.\n    return () => {\n      if (!router) {\n        console.warn(\"No router available to clean up from useFetcher()\");\n        return;\n      }\n      router.deleteFetcher(fetcherKey);\n    };\n  }, [router, fetcherKey]);\n  return fetcherWithComponents;\n}\n/**\n * Provides all fetchers currently on the page. Useful for layouts and parent\n * routes that need to provide pending/optimistic UI regarding the fetch.\n */\nfunction useFetchers() {\n  let state = useDataRouterState(DataRouterStateHook.UseFetchers);\n  return [...state.fetchers.values()];\n}\nconst SCROLL_RESTORATION_STORAGE_KEY = \"react-router-scroll-positions\";\nlet savedScrollPositions = {};\n/**\n * When rendered inside a RouterProvider, will restore scroll positions on navigations\n */\nfunction useScrollRestoration(_temp3) {\n  let {\n    getKey,\n    storageKey\n  } = _temp3 === void 0 ? {} : _temp3;\n  let {\n    router\n  } = useDataRouterContext(DataRouterHook.UseScrollRestoration);\n  let {\n    restoreScrollPosition,\n    preventScrollReset\n  } = useDataRouterState(DataRouterStateHook.UseScrollRestoration);\n  let {\n    basename\n  } = React.useContext(UNSAFE_NavigationContext);\n  let location = useLocation();\n  let matches = useMatches();\n  let navigation = useNavigation();\n  // Trigger manual scroll restoration while we're active\n  React.useEffect(() => {\n    window.history.scrollRestoration = \"manual\";\n    return () => {\n      window.history.scrollRestoration = \"auto\";\n    };\n  }, []);\n  // Save positions on pagehide\n  usePageHide(React.useCallback(() => {\n    if (navigation.state === \"idle\") {\n      let key = (getKey ? getKey(location, matches) : null) || location.key;\n      savedScrollPositions[key] = window.scrollY;\n    }\n    sessionStorage.setItem(storageKey || SCROLL_RESTORATION_STORAGE_KEY, JSON.stringify(savedScrollPositions));\n    window.history.scrollRestoration = \"auto\";\n  }, [storageKey, getKey, navigation.state, location, matches]));\n  // Read in any saved scroll locations\n  if (typeof document !== \"undefined\") {\n    // eslint-disable-next-line react-hooks/rules-of-hooks\n    React.useLayoutEffect(() => {\n      try {\n        let sessionPositions = sessionStorage.getItem(storageKey || SCROLL_RESTORATION_STORAGE_KEY);\n        if (sessionPositions) {\n          savedScrollPositions = JSON.parse(sessionPositions);\n        }\n      } catch (e) {\n        // no-op, use default empty object\n      }\n    }, [storageKey]);\n    // Enable scroll restoration in the router\n    // eslint-disable-next-line react-hooks/rules-of-hooks\n    React.useLayoutEffect(() => {\n      let getKeyWithoutBasename = getKey && basename !== \"/\" ? (location, matches) => getKey( // Strip the basename to match useLocation()\n      _extends({}, location, {\n        pathname: stripBasename(location.pathname, basename) || location.pathname\n      }), matches) : getKey;\n      let disableScrollRestoration = router == null ? void 0 : router.enableScrollRestoration(savedScrollPositions, () => window.scrollY, getKeyWithoutBasename);\n      return () => disableScrollRestoration && disableScrollRestoration();\n    }, [router, basename, getKey]);\n    // Restore scrolling when state.restoreScrollPosition changes\n    // eslint-disable-next-line react-hooks/rules-of-hooks\n    React.useLayoutEffect(() => {\n      // Explicit false means don't do anything (used for submissions)\n      if (restoreScrollPosition === false) {\n        return;\n      }\n      // been here before, scroll to it\n      if (typeof restoreScrollPosition === \"number\") {\n        window.scrollTo(0, restoreScrollPosition);\n        return;\n      }\n      // try to scroll to the hash\n      if (location.hash) {\n        let el = document.getElementById(decodeURIComponent(location.hash.slice(1)));\n        if (el) {\n          el.scrollIntoView();\n          return;\n        }\n      }\n      // Don't reset if this navigation opted out\n      if (preventScrollReset === true) {\n        return;\n      }\n      // otherwise go to the top on new locations\n      window.scrollTo(0, 0);\n    }, [location, restoreScrollPosition, preventScrollReset]);\n  }\n}\n/**\n * Setup a callback to be fired on the window's `beforeunload` event. This is\n * useful for saving some data to `window.localStorage` just before the page\n * refreshes.\n *\n * Note: The `callback` argument should be a function created with\n * `React.useCallback()`.\n */\nfunction useBeforeUnload(callback, options) {\n  let {\n    capture\n  } = options || {};\n  React.useEffect(() => {\n    let opts = capture != null ? {\n      capture\n    } : undefined;\n    window.addEventListener(\"beforeunload\", callback, opts);\n    return () => {\n      window.removeEventListener(\"beforeunload\", callback, opts);\n    };\n  }, [callback, capture]);\n}\n/**\n * Setup a callback to be fired on the window's `pagehide` event. This is\n * useful for saving some data to `window.localStorage` just before the page\n * refreshes.  This event is better supported than beforeunload across browsers.\n *\n * Note: The `callback` argument should be a function created with\n * `React.useCallback()`.\n */\nfunction usePageHide(callback, options) {\n  let {\n    capture\n  } = options || {};\n  React.useEffect(() => {\n    let opts = capture != null ? {\n      capture\n    } : undefined;\n    window.addEventListener(\"pagehide\", callback, opts);\n    return () => {\n      window.removeEventListener(\"pagehide\", callback, opts);\n    };\n  }, [callback, capture]);\n}\n/**\n * Wrapper around useBlocker to show a window.confirm prompt to users instead\n * of building a custom UI with useBlocker.\n *\n * Warning: This has *a lot of rough edges* and behaves very differently (and\n * very incorrectly in some cases) across browsers if user click addition\n * back/forward navigations while the confirm is open.  Use at your own risk.\n */\nfunction usePrompt(_ref8) {\n  let {\n    when,\n    message\n  } = _ref8;\n  let blocker = unstable_useBlocker(when);\n  React.useEffect(() => {\n    if (blocker.state === \"blocked\") {\n      let proceed = window.confirm(message);\n      if (proceed) {\n        // This timeout is needed to avoid a weird \"race\" on POP navigations\n        // between the `window.history` revert navigation and the result of\n        // `window.confirm`\n        setTimeout(blocker.proceed, 0);\n      } else {\n        blocker.reset();\n      }\n    }\n  }, [blocker, message]);\n  React.useEffect(() => {\n    if (blocker.state === \"blocked\" && !when) {\n      blocker.reset();\n    }\n  }, [blocker, when]);\n}\n//#endregion\n\nexport { BrowserRouter, Form, HashRouter, Link, NavLink, ScrollRestoration, useScrollRestoration as UNSAFE_useScrollRestoration, createBrowserRouter, createHashRouter, createSearchParams, HistoryRouter as unstable_HistoryRouter, usePrompt as unstable_usePrompt, useBeforeUnload, useFetcher, useFetchers, useFormAction, useLinkClickHandler, useSearchParams, useSubmit };\n//# sourceMappingURL=index.js.map\n"],"names":["React","UNSAFE_mapRouteProperties","Router","UNSAFE_NavigationContext","useHref","useResolvedPath","useLocation","UNSAFE_DataRouterStateContext","useNavigate","createPath","UNSAFE_useRouteId","UNSAFE_RouteContext","useMatches","useNavigation","unstable_useBlocker","UNSAFE_DataRouterContext","AbortedDeferredError","Await","MemoryRouter","Navigate","NavigationType","Outlet","Route","RouterProvider","Routes","UNSAFE_LocationContext","createMemoryRouter","createRoutesFromChildren","createRoutesFromElements","defer","generatePath","isRouteErrorResponse","json","matchPath","matchRoutes","parsePath","redirect","redirectDocument","renderMatches","resolvePath","useActionData","useAsyncError","useAsyncValue","useInRouterContext","useLoaderData","useMatch","useNavigationType","useOutlet","useOutletContext","useParams","useRevalidator","useRouteError","useRouteLoaderData","useRoutes","stripBasename","UNSAFE_warning","createRouter","createBrowserHistory","createHashHistory","ErrorResponse","UNSAFE_invariant","joinPaths","_extends","Object","assign","bind","target","i","arguments","length","source","key","prototype","hasOwnProperty","call","apply","_objectWithoutPropertiesLoose","excluded","sourceKeys","keys","indexOf","defaultMethod","defaultEncType","isHtmlElement","object","tagName","isButtonElement","toLowerCase","isFormElement","isInputElement","isModifiedEvent","event","metaKey","altKey","ctrlKey","shiftKey","shouldProcessLinkClick","button","createSearchParams","init","URLSearchParams","Array","isArray","reduce","memo","value","concat","map","v","getSearchParamsForLocation","locationSearch","defaultSearchParams","searchParams","forEach","_","has","getAll","append","_formDataSupportsSubmitter","isFormDataSubmitterSupported","FormData","document","createElement","e","supportedFormEncTypes","Set","getFormEncType","encType","getFormSubmissionInfo","basename","method","action","formData","body","attr","getAttribute","type","form","Error","name","prefix","undefined","_excluded","_excluded2","_excluded3","createBrowserRouter","routes","opts","future","v7_prependBasename","history","window","hydrationData","parseHydrationData","mapRouteProperties","initialize","createHashRouter","_window","state","__staticRouterHydrationData","errors","deserializeErrors","entries","serialized","val","__type","status","statusText","data","internal","__subType","ErrorConstructor","error","message","stack","START_TRANSITION","startTransitionImpl","BrowserRouter","_ref","children","historyRef","useRef","current","v5Compat","setStateImpl","useState","location","v7_startTransition","setState","useCallback","newState","useLayoutEffect","listen","navigationType","navigator","HashRouter","_ref2","HistoryRouter","_ref3","process","displayName","isBrowser","ABSOLUTE_URL_REGEX","Link","forwardRef","LinkWithRef","_ref4","ref","onClick","relative","reloadDocument","replace","to","preventScrollReset","rest","useContext","absoluteHref","isExternal","test","currentUrl","URL","href","targetUrl","startsWith","protocol","path","pathname","origin","search","hash","internalOnClick","useLinkClickHandler","handleClick","defaultPrevented","NavLink","NavLinkWithRef","_ref5","ariaCurrentProp","caseSensitive","className","classNameProp","end","style","styleProp","routerState","toPathname","encodeLocation","locationPathname","nextLocationPathname","navigation","isActive","charAt","isPending","ariaCurrent","filter","Boolean","join","Form","props","submit","useSubmit","FormImpl","_ref6","forwardedRef","onSubmit","formMethod","formAction","useFormAction","submitHandler","preventDefault","submitter","nativeEvent","submitMethod","currentTarget","ScrollRestoration","_ref7","getKey","storageKey","useScrollRestoration","DataRouterHook","DataRouterStateHook","getDataRouterConsoleError","hookName","useDataRouterContext","ctx","useDataRouterState","_temp","replaceProp","navigate","useSearchParams","defaultInit","defaultSearchParamsRef","hasSetSearchParamsRef","useMemo","setSearchParams","nextInit","navigateOptions","newSearchParams","validateClientSideSubmission","router","UseSubmit","currentRouteId","options","formEncType","fromRouteId","useSubmitFetcher","fetcherKey","fetcherRouteId","UseSubmitFetcher","fetch","_temp2","routeContext","match","matches","slice","route","index","params","delete","toString","createFetcherForm","routeId","FetcherForm","fetcherId","useFetcher","_route$matches","UseFetcher","id","String","load","fetcher","getFetcher","fetcherWithComponents","useEffect","console","warn","deleteFetcher","useFetchers","UseFetchers","fetchers","values","SCROLL_RESTORATION_STORAGE_KEY","savedScrollPositions","_temp3","UseScrollRestoration","restoreScrollPosition","scrollRestoration","usePageHide","scrollY","sessionStorage","setItem","JSON","stringify","sessionPositions","getItem","parse","getKeyWithoutBasename","disableScrollRestoration","enableScrollRestoration","scrollTo","el","getElementById","decodeURIComponent","scrollIntoView","useBeforeUnload","callback","capture","addEventListener","removeEventListener","usePrompt","_ref8","when","blocker","proceed","confirm","setTimeout","reset","UNSAFE_useScrollRestoration","unstable_HistoryRouter","unstable_usePrompt"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/react-router-dom/dist/index.js\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |