react-router-dom-v5-compat 6.4.0-pre.0 → 6.4.0-pre.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md ADDED
@@ -0,0 +1,13 @@
1
+ # react-router-dom-v5-compat
2
+
3
+ ## 6.4.0-pre.4
4
+
5
+ ### Patch Changes
6
+
7
+ - Fix missing `dist` files
8
+
9
+ ## 6.4.0-pre.3
10
+
11
+ ### Patch Changes
12
+
13
+ - Updated dependencies
File without changes
@@ -1,5 +1,5 @@
1
1
  /**
2
- * React Router DOM v5 Compat v6.4.0-pre.0
2
+ * React Router DOM v5 Compat v6.4.0-pre.4
3
3
  *
4
4
  * Copyright (c) Remix Software Inc.
5
5
  *
@@ -8,7 +8,7 @@
8
8
  *
9
9
  * @license MIT
10
10
  */
11
- import { useRef, useState, useLayoutEffect, createElement, forwardRef, useCallback, useContext, useMemo } from 'react';
11
+ import * as React from 'react';
12
12
  import { Router, useHref, createPath, useResolvedPath, useMatch, UNSAFE_DataRouterStateContext, useNavigate, useLocation, UNSAFE_DataRouterContext, UNSAFE_RouteContext, Routes, Route } from 'react-router';
13
13
  export { MemoryRouter, Navigate, NavigationType, Outlet, Route, Router, Routes, UNSAFE_LocationContext, UNSAFE_NavigationContext, UNSAFE_RouteContext, createPath, createRoutesFromChildren, generatePath, matchPath, matchRoutes, parsePath, renderMatches, resolvePath, useHref, useInRouterContext, useLocation, useMatch, useNavigate, useNavigationType, useOutlet, useOutletContext, useParams, useResolvedPath, useRoutes } from 'react-router';
14
14
  import { createBrowserHistory, createHashHistory, matchPath, invariant } from '@remix-run/router';
@@ -16,7 +16,7 @@ import { parsePath, Action, createPath as createPath$1 } from 'history';
16
16
  import { Route as Route$1, useHistory } from 'react-router-dom';
17
17
 
18
18
  function _extends() {
19
- _extends = Object.assign || function (target) {
19
+ _extends = Object.assign ? Object.assign.bind() : function (target) {
20
20
  for (var i = 1; i < arguments.length; i++) {
21
21
  var source = arguments[i];
22
22
 
@@ -29,7 +29,6 @@ function _extends() {
29
29
 
30
30
  return target;
31
31
  };
32
-
33
32
  return _extends.apply(this, arguments);
34
33
  }
35
34
 
@@ -73,7 +72,6 @@ function shouldProcessLinkClick(event, target) {
73
72
  !isModifiedEvent(event) // Ignore clicks with modifier keys
74
73
  ;
75
74
  }
76
-
77
75
  /**
78
76
  * Creates a URLSearchParams object using the given initializer.
79
77
  *
@@ -95,6 +93,7 @@ function shouldProcessLinkClick(event, target) {
95
93
  * sort: ['name', 'price']
96
94
  * });
97
95
  */
96
+
98
97
  function createSearchParams(init) {
99
98
  if (init === void 0) {
100
99
  init = "";
@@ -179,17 +178,6 @@ function getFormSubmissionInfo(target, defaultAction, options) {
179
178
  host
180
179
  } = window.location;
181
180
  let url = new URL(action, protocol + "//" + host);
182
-
183
- if (method.toLowerCase() === "get") {
184
- for (let [name, value] of formData) {
185
- if (typeof value === "string") {
186
- url.searchParams.append(name, value);
187
- } else {
188
- throw new Error("Cannot submit binary form data using GET");
189
- }
190
- }
191
- }
192
-
193
181
  return {
194
182
  url,
195
183
  method,
@@ -201,17 +189,17 @@ function getFormSubmissionInfo(target, defaultAction, options) {
201
189
  const _excluded = ["onClick", "reloadDocument", "replace", "state", "target", "to", "resetScroll"],
202
190
  _excluded2 = ["aria-current", "caseSensitive", "className", "end", "style", "to", "children"],
203
191
  _excluded3 = ["replace", "method", "action", "onSubmit", "fetcherKey"];
204
-
205
192
  /**
206
193
  * A `<Router>` for use in web browsers. Provides the cleanest URLs.
207
194
  */
195
+
208
196
  function BrowserRouter(_ref3) {
209
197
  let {
210
198
  basename,
211
199
  children,
212
200
  window
213
201
  } = _ref3;
214
- let historyRef = useRef();
202
+ let historyRef = React.useRef();
215
203
 
216
204
  if (historyRef.current == null) {
217
205
  historyRef.current = createBrowserHistory({
@@ -221,12 +209,12 @@ function BrowserRouter(_ref3) {
221
209
  }
222
210
 
223
211
  let history = historyRef.current;
224
- let [state, setState] = useState({
212
+ let [state, setState] = React.useState({
225
213
  action: history.action,
226
214
  location: history.location
227
215
  });
228
- useLayoutEffect(() => history.listen(setState), [history]);
229
- return /*#__PURE__*/createElement(Router, {
216
+ React.useLayoutEffect(() => history.listen(setState), [history]);
217
+ return /*#__PURE__*/React.createElement(Router, {
230
218
  basename: basename,
231
219
  children: children,
232
220
  location: state.location,
@@ -234,18 +222,18 @@ function BrowserRouter(_ref3) {
234
222
  navigator: history
235
223
  });
236
224
  }
237
-
238
225
  /**
239
226
  * A `<Router>` for use in web browsers. Stores the location in the hash
240
227
  * portion of the URL so it is not sent to the server.
241
228
  */
229
+
242
230
  function HashRouter(_ref4) {
243
231
  let {
244
232
  basename,
245
233
  children,
246
234
  window
247
235
  } = _ref4;
248
- let historyRef = useRef();
236
+ let historyRef = React.useRef();
249
237
 
250
238
  if (historyRef.current == null) {
251
239
  historyRef.current = createHashHistory({
@@ -255,12 +243,12 @@ function HashRouter(_ref4) {
255
243
  }
256
244
 
257
245
  let history = historyRef.current;
258
- let [state, setState] = useState({
246
+ let [state, setState] = React.useState({
259
247
  action: history.action,
260
248
  location: history.location
261
249
  });
262
- useLayoutEffect(() => history.listen(setState), [history]);
263
- return /*#__PURE__*/createElement(Router, {
250
+ React.useLayoutEffect(() => history.listen(setState), [history]);
251
+ return /*#__PURE__*/React.createElement(Router, {
264
252
  basename: basename,
265
253
  children: children,
266
254
  location: state.location,
@@ -268,25 +256,25 @@ function HashRouter(_ref4) {
268
256
  navigator: history
269
257
  });
270
258
  }
271
-
272
259
  /**
273
260
  * A `<Router>` that accepts a pre-instantiated history object. It's important
274
261
  * to note that using your own history object is highly discouraged and may add
275
262
  * two versions of the history library to your bundles unless you use the same
276
263
  * version of the history library that React Router uses internally.
277
264
  */
265
+
278
266
  function HistoryRouter(_ref5) {
279
267
  let {
280
268
  basename,
281
269
  children,
282
270
  history
283
271
  } = _ref5;
284
- const [state, setState] = useState({
272
+ const [state, setState] = React.useState({
285
273
  action: history.action,
286
274
  location: history.location
287
275
  });
288
- useLayoutEffect(() => history.listen(setState), [history]);
289
- return /*#__PURE__*/createElement(Router, {
276
+ React.useLayoutEffect(() => history.listen(setState), [history]);
277
+ return /*#__PURE__*/React.createElement(Router, {
290
278
  basename: basename,
291
279
  children: children,
292
280
  location: state.location,
@@ -298,15 +286,15 @@ function HistoryRouter(_ref5) {
298
286
  if (process.env.NODE_ENV !== "production") {
299
287
  HistoryRouter.displayName = "unstable_HistoryRouter";
300
288
  }
301
-
302
289
  /**
303
290
  * The public API for rendering a history-aware <a>.
304
291
  */
305
- const Link = /*#__PURE__*/forwardRef(function LinkWithRef(_ref6, ref) {
292
+
293
+ const Link = /*#__PURE__*/React.forwardRef(function LinkWithRef(_ref6, ref) {
306
294
  let {
307
295
  onClick,
308
296
  reloadDocument,
309
- replace = false,
297
+ replace,
310
298
  state,
311
299
  target,
312
300
  to,
@@ -333,7 +321,7 @@ const Link = /*#__PURE__*/forwardRef(function LinkWithRef(_ref6, ref) {
333
321
  return (
334
322
  /*#__PURE__*/
335
323
  // eslint-disable-next-line jsx-a11y/anchor-has-content
336
- createElement("a", _extends({}, rest, {
324
+ React.createElement("a", _extends({}, rest, {
337
325
  href: href,
338
326
  onClick: handleClick,
339
327
  ref: ref,
@@ -345,11 +333,12 @@ const Link = /*#__PURE__*/forwardRef(function LinkWithRef(_ref6, ref) {
345
333
  if (process.env.NODE_ENV !== "production") {
346
334
  Link.displayName = "Link";
347
335
  }
348
-
349
336
  /**
350
337
  * A <Link> wrapper that knows if it's "active" or not.
351
338
  */
352
- const NavLink = /*#__PURE__*/forwardRef(function NavLinkWithRef(_ref7, ref) {
339
+
340
+
341
+ const NavLink = /*#__PURE__*/React.forwardRef(function NavLinkWithRef(_ref7, ref) {
353
342
  let {
354
343
  "aria-current": ariaCurrentProp = "page",
355
344
  caseSensitive = false,
@@ -367,10 +356,10 @@ const NavLink = /*#__PURE__*/forwardRef(function NavLinkWithRef(_ref7, ref) {
367
356
  end,
368
357
  caseSensitive
369
358
  });
370
- let routerState = useContext(UNSAFE_DataRouterStateContext);
359
+ let routerState = React.useContext(UNSAFE_DataRouterStateContext);
371
360
  let nextLocation = routerState == null ? void 0 : routerState.navigation.location;
372
361
  let nextPath = useResolvedPath(nextLocation || "");
373
- let nextMatch = useMemo(() => nextLocation ? matchPath({
362
+ let nextMatch = React.useMemo(() => nextLocation ? matchPath({
374
363
  path: path.pathname,
375
364
  end,
376
365
  caseSensitive
@@ -398,7 +387,7 @@ const NavLink = /*#__PURE__*/forwardRef(function NavLinkWithRef(_ref7, ref) {
398
387
  isActive,
399
388
  isPending
400
389
  }) : styleProp;
401
- return /*#__PURE__*/createElement(Link, _extends({}, rest, {
390
+ return /*#__PURE__*/React.createElement(Link, _extends({}, rest, {
402
391
  "aria-current": ariaCurrent,
403
392
  className: className,
404
393
  ref: ref,
@@ -413,15 +402,16 @@ const NavLink = /*#__PURE__*/forwardRef(function NavLinkWithRef(_ref7, ref) {
413
402
  if (process.env.NODE_ENV !== "production") {
414
403
  NavLink.displayName = "NavLink";
415
404
  }
416
-
417
405
  /**
418
406
  * A `@remix-run/router`-aware `<form>`. It behaves like a normal form except
419
407
  * that the interaction with the server is with `fetch` instead of new document
420
408
  * requests, allowing components to add nicer UX to the page as the form is
421
409
  * submitted and returns with data.
422
410
  */
423
- const Form = /*#__PURE__*/forwardRef((props, ref) => {
424
- return /*#__PURE__*/createElement(FormImpl, _extends({}, props, {
411
+
412
+
413
+ const Form = /*#__PURE__*/React.forwardRef((props, ref) => {
414
+ return /*#__PURE__*/React.createElement(FormImpl, _extends({}, props, {
425
415
  ref: ref
426
416
  }));
427
417
  });
@@ -430,7 +420,7 @@ if (process.env.NODE_ENV !== "production") {
430
420
  Form.displayName = "Form";
431
421
  }
432
422
 
433
- const FormImpl = /*#__PURE__*/forwardRef((_ref8, forwardedRef) => {
423
+ const FormImpl = /*#__PURE__*/React.forwardRef((_ref8, forwardedRef) => {
434
424
  let {
435
425
  replace,
436
426
  method = defaultMethod,
@@ -455,7 +445,7 @@ const FormImpl = /*#__PURE__*/forwardRef((_ref8, forwardedRef) => {
455
445
  });
456
446
  };
457
447
 
458
- return /*#__PURE__*/createElement("form", _extends({
448
+ return /*#__PURE__*/React.createElement("form", _extends({
459
449
  ref: forwardedRef,
460
450
  method: formMethod,
461
451
  action: formAction,
@@ -489,23 +479,16 @@ function useLinkClickHandler(to, _temp) {
489
479
  let navigate = useNavigate();
490
480
  let location = useLocation();
491
481
  let path = useResolvedPath(to);
492
- return useCallback(event => {
482
+ return React.useCallback(event => {
493
483
  if (shouldProcessLinkClick(event, target)) {
494
484
  event.preventDefault(); // If the URL hasn't changed, a regular <a> will do a replace instead of
495
- // a push, so do the same here.
496
-
497
- let replace = !!replaceProp || createPath(location) === createPath(path);
498
- let newState = state;
499
-
500
- if (resetScroll === false) {
501
- newState = _extends({}, state, {
502
- __resetScrollPosition: false
503
- });
504
- }
485
+ // a push, so do the same here unless the replace prop is explcitly set
505
486
 
487
+ let replace = replaceProp !== undefined ? replaceProp : createPath(location) === createPath(path);
506
488
  navigate(to, {
507
489
  replace,
508
- state: newState
490
+ state,
491
+ resetScroll
509
492
  });
510
493
  }
511
494
  }, [location, navigate, path, replaceProp, state, target, to, resetScroll]);
@@ -517,20 +500,20 @@ function useLinkClickHandler(to, _temp) {
517
500
 
518
501
  function useSearchParams(defaultInit) {
519
502
  process.env.NODE_ENV !== "production" ? 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;
520
- let defaultSearchParamsRef = useRef(createSearchParams(defaultInit));
503
+ let defaultSearchParamsRef = React.useRef(createSearchParams(defaultInit));
521
504
  let location = useLocation();
522
- let searchParams = useMemo(() => getSearchParamsForLocation(location.search, defaultSearchParamsRef.current), [location.search]);
505
+ let searchParams = React.useMemo(() => getSearchParamsForLocation(location.search, defaultSearchParamsRef.current), [location.search]);
523
506
  let navigate = useNavigate();
524
- let setSearchParams = useCallback((nextInit, navigateOptions) => {
507
+ let setSearchParams = React.useCallback((nextInit, navigateOptions) => {
525
508
  navigate("?" + createSearchParams(nextInit), navigateOptions);
526
509
  }, [navigate]);
527
510
  return [searchParams, setSearchParams];
528
511
  }
529
512
 
530
513
  function useSubmitImpl(fetcherKey) {
531
- let router = useContext(UNSAFE_DataRouterContext);
514
+ let router = React.useContext(UNSAFE_DataRouterContext);
532
515
  let defaultAction = useFormAction();
533
- return useCallback(function (target, options) {
516
+ return React.useCallback(function (target, options) {
534
517
  if (options === void 0) {
535
518
  options = {};
536
519
  }
@@ -570,8 +553,8 @@ function useFormAction(action) {
570
553
  action = ".";
571
554
  }
572
555
 
573
- let routeContext = useContext(UNSAFE_RouteContext);
574
- !routeContext ? process.env.NODE_ENV !== "production" ? invariant(false, "useLoaderData must be used inside a RouteContext") : invariant(false) : void 0;
556
+ let routeContext = React.useContext(UNSAFE_RouteContext);
557
+ !routeContext ? process.env.NODE_ENV !== "production" ? invariant(false, "useFormAction must be used inside a RouteContext") : invariant(false) : void 0;
575
558
  let [match] = routeContext.matches.slice(-1);
576
559
  let {
577
560
  pathname,
@@ -612,9 +595,9 @@ function CompatRoute(props) {
612
595
  path
613
596
  } = props;
614
597
  if (!props.exact) path += "/*";
615
- return /*#__PURE__*/createElement(Routes, null, /*#__PURE__*/createElement(Route, {
598
+ return /*#__PURE__*/React.createElement(Routes, null, /*#__PURE__*/React.createElement(Route, {
616
599
  path: path,
617
- element: /*#__PURE__*/createElement(Route$1, props)
600
+ element: /*#__PURE__*/React.createElement(Route$1, _extends({}, props))
618
601
  }));
619
602
  }
620
603
  function CompatRouter(_ref) {
@@ -622,30 +605,30 @@ function CompatRouter(_ref) {
622
605
  children
623
606
  } = _ref;
624
607
  let history = useHistory();
625
- let [state, setState] = useState(() => ({
608
+ let [state, setState] = React.useState(() => ({
626
609
  location: history.location,
627
610
  action: history.action
628
611
  }));
629
- useLayoutEffect(() => {
612
+ React.useLayoutEffect(() => {
630
613
  history.listen((location, action) => setState({
631
614
  location,
632
615
  action
633
616
  }));
634
617
  }, [history]);
635
- return /*#__PURE__*/createElement(Router, {
618
+ return /*#__PURE__*/React.createElement(Router, {
636
619
  navigationType: state.action,
637
620
  location: state.location,
638
621
  navigator: history
639
- }, /*#__PURE__*/createElement(Routes, null, /*#__PURE__*/createElement(Route, {
622
+ }, /*#__PURE__*/React.createElement(Routes, null, /*#__PURE__*/React.createElement(Route, {
640
623
  path: "*",
641
624
  element: children
642
625
  })));
643
626
  }
644
-
645
627
  /**
646
628
  * A <Router> that may not navigate to any other location. This is useful
647
629
  * on the server where there is no stateful UI.
648
630
  */
631
+
649
632
  function StaticRouter(_ref2) {
650
633
  let {
651
634
  basename,
@@ -691,7 +674,7 @@ function StaticRouter(_ref2) {
691
674
  }
692
675
 
693
676
  };
694
- return /*#__PURE__*/createElement(Router, {
677
+ return /*#__PURE__*/React.createElement(Router, {
695
678
  basename: basename,
696
679
  children: children,
697
680
  location: location,
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../react-router-dom/dom.ts","../react-router-dom/index.tsx","../lib/components.tsx"],"sourcesContent":["import type { FormEncType, FormMethod } from \"@remix-run/router\";\n\nexport const defaultMethod = \"get\";\nconst defaultEncType = \"application/x-www-form-urlencoded\";\n\nexport function isHtmlElement(object: any): object is HTMLElement {\n return object != null && typeof object.tagName === \"string\";\n}\n\nexport function isButtonElement(object: any): object is HTMLButtonElement {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"button\";\n}\n\nexport function isFormElement(object: any): object is HTMLFormElement {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"form\";\n}\n\nexport function isInputElement(object: any): object is HTMLInputElement {\n return isHtmlElement(object) && object.tagName.toLowerCase() === \"input\";\n}\n\ntype LimitedMouseEvent = Pick<\n MouseEvent,\n \"button\" | \"metaKey\" | \"altKey\" | \"ctrlKey\" | \"shiftKey\"\n>;\n\nfunction isModifiedEvent(event: LimitedMouseEvent) {\n return !!(event.metaKey || event.altKey || event.ctrlKey || event.shiftKey);\n}\n\nexport function shouldProcessLinkClick(\n event: LimitedMouseEvent,\n target?: string\n) {\n return (\n 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\nexport type ParamKeyValuePair = [string, string];\n\nexport type URLSearchParamsInit =\n | string\n | ParamKeyValuePair[]\n | Record<string, string | string[]>\n | URLSearchParams;\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 */\nexport function createSearchParams(\n init: URLSearchParamsInit = \"\"\n): URLSearchParams {\n return new URLSearchParams(\n typeof init === \"string\" ||\n Array.isArray(init) ||\n init instanceof URLSearchParams\n ? init\n : Object.keys(init).reduce((memo, key) => {\n let value = init[key];\n return memo.concat(\n Array.isArray(value) ? value.map((v) => [key, v]) : [[key, value]]\n );\n }, [] as ParamKeyValuePair[])\n );\n}\n\nexport function getSearchParamsForLocation(\n locationSearch: string,\n defaultSearchParams: URLSearchParams\n) {\n let searchParams = createSearchParams(locationSearch);\n\n for (let key of defaultSearchParams.keys()) {\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\nexport interface SubmitOptions {\n /**\n * The HTTP method used to submit the form. Overrides `<form method>`.\n * Defaults to \"GET\".\n */\n method?: FormMethod;\n\n /**\n * The action URL path used to submit the form. Overrides `<form action>`.\n * Defaults to the path of the current route.\n *\n * Note: It is assumed the path is already resolved. If you need to resolve a\n * relative path, use `useFormAction`.\n */\n action?: string;\n\n /**\n * The action URL used to submit the form. Overrides `<form encType>`.\n * Defaults to \"application/x-www-form-urlencoded\".\n */\n encType?: FormEncType;\n\n /**\n * Set `true` to replace the current entry in the browser's history stack\n * instead of creating a new one (i.e. stay on \"the same page\"). Defaults\n * to `false`.\n */\n replace?: boolean;\n}\n\nexport function getFormSubmissionInfo(\n target:\n | HTMLFormElement\n | HTMLButtonElement\n | HTMLInputElement\n | FormData\n | URLSearchParams\n | { [name: string]: string }\n | null,\n defaultAction: string,\n options: SubmitOptions\n): {\n url: URL;\n method: string;\n encType: string;\n formData: FormData;\n} {\n let method: string;\n let action: string;\n let encType: string;\n let formData: FormData;\n\n if (isFormElement(target)) {\n let submissionTrigger: HTMLButtonElement | HTMLInputElement = (\n options as any\n ).submissionTrigger;\n\n method = options.method || target.getAttribute(\"method\") || defaultMethod;\n action = options.action || target.getAttribute(\"action\") || defaultAction;\n encType =\n options.encType || target.getAttribute(\"enctype\") || defaultEncType;\n\n formData = new FormData(target);\n\n if (submissionTrigger && submissionTrigger.name) {\n formData.append(submissionTrigger.name, submissionTrigger.value);\n }\n } else if (\n isButtonElement(target) ||\n (isInputElement(target) &&\n (target.type === \"submit\" || target.type === \"image\"))\n ) {\n let form = target.form;\n\n if (form == null) {\n throw new Error(\n `Cannot submit a <button> or <input type=\"submit\"> without a <form>`\n );\n }\n\n // <button>/<input type=\"submit\"> may override attributes of <form>\n\n method =\n options.method ||\n target.getAttribute(\"formmethod\") ||\n form.getAttribute(\"method\") ||\n defaultMethod;\n action =\n options.action ||\n target.getAttribute(\"formaction\") ||\n form.getAttribute(\"action\") ||\n defaultAction;\n encType =\n options.encType ||\n target.getAttribute(\"formenctype\") ||\n form.getAttribute(\"enctype\") ||\n defaultEncType;\n\n formData = new FormData(form);\n\n // Include name + value from a <button>\n if (target.name) {\n formData.set(target.name, target.value);\n }\n } else if (isHtmlElement(target)) {\n throw new Error(\n `Cannot submit element that is not <form>, <button>, or ` +\n `<input type=\"submit|image\">`\n );\n } else {\n method = options.method || defaultMethod;\n action = options.action || defaultAction;\n encType = options.encType || defaultEncType;\n\n if (target instanceof FormData) {\n formData = target;\n } else {\n formData = new FormData();\n\n if (target instanceof URLSearchParams) {\n for (let [name, value] of target) {\n formData.append(name, value);\n }\n } else if (target != null) {\n for (let name of Object.keys(target)) {\n formData.append(name, target[name]);\n }\n }\n }\n }\n\n let { protocol, host } = window.location;\n let url = new URL(action, `${protocol}//${host}`);\n\n return { url, method, encType, formData };\n}\n","/**\n * NOTE: If you refactor this to split up the modules into separate files,\n * you'll need to update the rollup config for react-router-dom-v5-compat.\n */\nimport * as React from \"react\";\nimport {\n Router,\n createPath,\n useHref,\n useLocation,\n useMatch,\n useNavigate,\n useRenderDataRouter,\n useResolvedPath,\n UNSAFE_RouteContext,\n UNSAFE_DataRouterContext,\n UNSAFE_DataRouterStateContext,\n} from \"react-router\";\nimport type { To } from \"react-router\";\nimport type {\n BrowserHistory,\n Fetcher,\n FormEncType,\n FormMethod,\n HashHistory,\n History,\n HydrationState,\n GetScrollRestorationKeyFunction,\n RouteObject,\n} from \"@remix-run/router\";\nimport {\n createBrowserHistory,\n createHashHistory,\n createBrowserRouter,\n createHashRouter,\n invariant,\n matchPath,\n} from \"@remix-run/router\";\n\nimport type {\n SubmitOptions,\n ParamKeyValuePair,\n URLSearchParamsInit,\n} from \"./dom\";\nimport {\n createSearchParams,\n defaultMethod,\n getFormSubmissionInfo,\n getSearchParamsForLocation,\n shouldProcessLinkClick,\n} from \"./dom\";\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Re-exports\n////////////////////////////////////////////////////////////////////////////////\n\nexport type { ParamKeyValuePair, URLSearchParamsInit };\nexport { createSearchParams };\n\n// Note: Keep in sync with react-router exports!\nexport type {\n ActionFunction,\n DataMemoryRouterProps,\n DataRouteMatch,\n Fetcher,\n Hash,\n IndexRouteProps,\n JsonFunction,\n LayoutRouteProps,\n LoaderFunction,\n Location,\n MemoryRouterProps,\n NavigateFunction,\n NavigateOptions,\n NavigateProps,\n Navigation,\n Navigator,\n OutletProps,\n Params,\n Path,\n PathMatch,\n Pathname,\n PathPattern,\n PathRouteProps,\n RedirectFunction,\n RouteMatch,\n RouteObject,\n RouteProps,\n RouterProps,\n RoutesProps,\n Search,\n ShouldRevalidateFunction,\n To,\n} from \"react-router\";\nexport {\n DataMemoryRouter,\n MemoryRouter,\n Navigate,\n NavigationType,\n Outlet,\n Route,\n Router,\n Routes,\n createPath,\n createRoutesFromChildren,\n isRouteErrorResponse,\n generatePath,\n json,\n matchPath,\n matchRoutes,\n parsePath,\n redirect,\n renderMatches,\n resolvePath,\n useActionData,\n useHref,\n useInRouterContext,\n useLoaderData,\n useLocation,\n useMatch,\n useMatches,\n useNavigate,\n useNavigation,\n useNavigationType,\n useOutlet,\n useOutletContext,\n useParams,\n useResolvedPath,\n useRevalidator,\n useRouteError,\n useRouteLoaderData,\n useRoutes,\n} from \"react-router\";\n\n///////////////////////////////////////////////////////////////////////////////\n// DANGER! PLEASE READ ME!\n// We provide these exports as an escape hatch in the event that you need any\n// routing data that we don't provide an explicit API for. With that said, we\n// want to cover your use case if we can, so if you feel the need to use these\n// we want to hear from you. Let us know what you're building and we'll do our\n// best to make sure we can support you!\n//\n// We consider these exports an implementation detail and do not guarantee\n// against any breaking changes, regardless of the semver release. Use with\n// extreme caution and only if you understand the consequences. Godspeed.\n///////////////////////////////////////////////////////////////////////////////\n\n/** @internal */\nexport {\n UNSAFE_NavigationContext,\n UNSAFE_LocationContext,\n UNSAFE_RouteContext,\n UNSAFE_DataRouterContext,\n UNSAFE_DataRouterStateContext,\n useRenderDataRouter,\n} from \"react-router\";\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Components\n////////////////////////////////////////////////////////////////////////////////\n\nexport interface DataBrowserRouterProps {\n children?: React.ReactNode;\n hydrationData?: HydrationState;\n fallbackElement?: React.ReactNode;\n routes?: RouteObject[];\n window?: Window;\n}\n\nexport function DataBrowserRouter({\n children,\n fallbackElement,\n hydrationData,\n routes,\n window,\n}: DataBrowserRouterProps): React.ReactElement {\n return useRenderDataRouter({\n children,\n fallbackElement,\n routes,\n createRouter: (routes) =>\n createBrowserRouter({\n routes,\n hydrationData,\n window,\n }),\n });\n}\n\nexport interface DataHashRouterProps {\n children?: React.ReactNode;\n hydrationData?: HydrationState;\n fallbackElement?: React.ReactNode;\n routes?: RouteObject[];\n window?: Window;\n}\n\nexport function DataHashRouter({\n children,\n hydrationData,\n fallbackElement,\n routes,\n window,\n}: DataBrowserRouterProps): React.ReactElement {\n return useRenderDataRouter({\n children,\n fallbackElement,\n routes,\n createRouter: (routes) =>\n createHashRouter({\n routes,\n hydrationData,\n window,\n }),\n });\n}\n\nexport interface BrowserRouterProps {\n basename?: string;\n children?: React.ReactNode;\n window?: Window;\n}\n\n/**\n * A `<Router>` for use in web browsers. Provides the cleanest URLs.\n */\nexport function BrowserRouter({\n basename,\n children,\n window,\n}: BrowserRouterProps) {\n let historyRef = React.useRef<BrowserHistory>();\n if (historyRef.current == null) {\n historyRef.current = createBrowserHistory({ window, v5Compat: true });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n <Router\n basename={basename}\n children={children}\n location={state.location}\n navigationType={state.action}\n navigator={history}\n />\n );\n}\n\nexport interface HashRouterProps {\n basename?: string;\n children?: React.ReactNode;\n window?: Window;\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 */\nexport function HashRouter({ basename, children, window }: HashRouterProps) {\n let historyRef = React.useRef<HashHistory>();\n if (historyRef.current == null) {\n historyRef.current = createHashHistory({ window, v5Compat: true });\n }\n\n let history = historyRef.current;\n let [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n <Router\n basename={basename}\n children={children}\n location={state.location}\n navigationType={state.action}\n navigator={history}\n />\n );\n}\n\nexport interface HistoryRouterProps {\n basename?: string;\n children?: React.ReactNode;\n history: 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({ basename, children, history }: HistoryRouterProps) {\n const [state, setState] = React.useState({\n action: history.action,\n location: history.location,\n });\n\n React.useLayoutEffect(() => history.listen(setState), [history]);\n\n return (\n <Router\n basename={basename}\n children={children}\n location={state.location}\n navigationType={state.action}\n navigator={history}\n />\n );\n}\n\nif (__DEV__) {\n HistoryRouter.displayName = \"unstable_HistoryRouter\";\n}\n\nexport { HistoryRouter as unstable_HistoryRouter };\n\nexport interface LinkProps\n extends Omit<React.AnchorHTMLAttributes<HTMLAnchorElement>, \"href\"> {\n reloadDocument?: boolean;\n replace?: boolean;\n state?: any;\n resetScroll?: boolean;\n to: To;\n}\n\n/**\n * The public API for rendering a history-aware <a>.\n */\nexport const Link = React.forwardRef<HTMLAnchorElement, LinkProps>(\n function LinkWithRef(\n {\n onClick,\n reloadDocument,\n replace,\n state,\n target,\n to,\n resetScroll,\n ...rest\n },\n ref\n ) {\n let href = useHref(to);\n let internalOnClick = useLinkClickHandler(to, {\n replace,\n state,\n target,\n resetScroll,\n });\n function handleClick(\n event: React.MouseEvent<HTMLAnchorElement, MouseEvent>\n ) {\n if (onClick) onClick(event);\n if (!event.defaultPrevented && !reloadDocument) {\n internalOnClick(event);\n }\n }\n\n return (\n // eslint-disable-next-line jsx-a11y/anchor-has-content\n <a\n {...rest}\n href={href}\n onClick={handleClick}\n ref={ref}\n target={target}\n />\n );\n }\n);\n\nif (__DEV__) {\n Link.displayName = \"Link\";\n}\n\nexport interface NavLinkProps\n extends Omit<LinkProps, \"className\" | \"style\" | \"children\"> {\n children?:\n | React.ReactNode\n | ((props: { isActive: boolean; isPending: boolean }) => React.ReactNode);\n caseSensitive?: boolean;\n className?:\n | string\n | ((props: {\n isActive: boolean;\n isPending: boolean;\n }) => string | undefined);\n end?: boolean;\n style?:\n | React.CSSProperties\n | ((props: {\n isActive: boolean;\n isPending: boolean;\n }) => React.CSSProperties | undefined);\n}\n\n/**\n * A <Link> wrapper that knows if it's \"active\" or not.\n */\nexport const NavLink = React.forwardRef<HTMLAnchorElement, NavLinkProps>(\n function NavLinkWithRef(\n {\n \"aria-current\": ariaCurrentProp = \"page\",\n caseSensitive = false,\n className: classNameProp = \"\",\n end = false,\n style: styleProp,\n to,\n children,\n ...rest\n },\n ref\n ) {\n let path = useResolvedPath(to);\n let match = useMatch({ path: path.pathname, end, caseSensitive });\n\n let routerState = React.useContext(UNSAFE_DataRouterStateContext);\n let nextLocation = routerState?.navigation.location;\n let nextPath = useResolvedPath(nextLocation || \"\");\n let nextMatch = React.useMemo(\n () =>\n nextLocation\n ? matchPath(\n { path: path.pathname, end, caseSensitive },\n nextPath.pathname\n )\n : null,\n [nextLocation, path.pathname, caseSensitive, end, nextPath.pathname]\n );\n\n let isPending = nextMatch != null;\n let isActive = match != null;\n\n let ariaCurrent = isActive ? ariaCurrentProp : undefined;\n\n let className: string | undefined;\n if (typeof classNameProp === \"function\") {\n className = classNameProp({ isActive, isPending });\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 ]\n .filter(Boolean)\n .join(\" \");\n }\n\n let style =\n typeof styleProp === \"function\"\n ? styleProp({ isActive, isPending })\n : styleProp;\n\n return (\n <Link\n {...rest}\n aria-current={ariaCurrent}\n className={className}\n ref={ref}\n style={style}\n to={to}\n >\n {typeof children === \"function\"\n ? children({ isActive, isPending })\n : children}\n </Link>\n );\n }\n);\n\nif (__DEV__) {\n NavLink.displayName = \"NavLink\";\n}\n\nexport interface FormProps extends React.FormHTMLAttributes<HTMLFormElement> {\n /**\n * The HTTP verb to use when the form is submit. Supports \"get\", \"post\",\n * \"put\", \"delete\", \"patch\".\n */\n method?: FormMethod;\n\n /**\n * Normal `<form action>` but supports React Router's relative paths.\n */\n action?: string;\n\n /**\n * Replaces the current entry in the browser history stack when the form\n * navigates. Use this if you don't want the user to be able to click \"back\"\n * to the page with the form on it.\n */\n replace?: boolean;\n\n /**\n * A function to call when the form is submitted. If you call\n * `event.preventDefault()` then this form will not do anything.\n */\n onSubmit?: React.FormEventHandler<HTMLFormElement>;\n}\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 */\nexport const Form = React.forwardRef<HTMLFormElement, FormProps>(\n (props, ref) => {\n return <FormImpl {...props} ref={ref} />;\n }\n);\n\nif (__DEV__) {\n Form.displayName = \"Form\";\n}\n\ntype HTMLSubmitEvent = React.BaseSyntheticEvent<\n SubmitEvent,\n Event,\n HTMLFormElement\n>;\n\ntype HTMLFormSubmitter = HTMLButtonElement | HTMLInputElement;\n\ninterface FormImplProps extends FormProps {\n fetcherKey?: string;\n}\n\nconst FormImpl = React.forwardRef<HTMLFormElement, FormImplProps>(\n (\n {\n replace,\n method = defaultMethod,\n action = \".\",\n onSubmit,\n fetcherKey,\n ...props\n },\n forwardedRef\n ) => {\n let submit = useSubmitImpl(fetcherKey);\n let formMethod: FormMethod =\n method.toLowerCase() === \"get\" ? \"get\" : \"post\";\n let formAction = useFormAction(action);\n let submitHandler: React.FormEventHandler<HTMLFormElement> = (event) => {\n onSubmit && onSubmit(event);\n if (event.defaultPrevented) return;\n event.preventDefault();\n\n let submitter = (event as unknown as HTMLSubmitEvent).nativeEvent\n .submitter as HTMLFormSubmitter | null;\n\n submit(submitter || event.currentTarget, { method, replace });\n };\n\n return (\n <form\n ref={forwardedRef}\n method={formMethod}\n action={formAction}\n onSubmit={submitHandler}\n {...props}\n />\n );\n }\n);\n\nif (__DEV__) {\n Form.displayName = \"Form\";\n}\n\ninterface ScrollRestorationProps {\n getKey?: GetScrollRestorationKeyFunction;\n storageKey?: string;\n}\n\n/**\n * This component will emulate the browser's scroll restoration on location\n * changes.\n */\nexport function ScrollRestoration({\n getKey,\n storageKey,\n}: ScrollRestorationProps) {\n useScrollRestoration({ getKey, storageKey });\n return null;\n}\n\nif (__DEV__) {\n ScrollRestoration.displayName = \"ScrollRestoration\";\n}\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Hooks\n////////////////////////////////////////////////////////////////////////////////\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 */\nexport function useLinkClickHandler<E extends Element = HTMLAnchorElement>(\n to: To,\n {\n target,\n replace: replaceProp,\n state,\n resetScroll,\n }: {\n target?: React.HTMLAttributeAnchorTarget;\n replace?: boolean;\n state?: any;\n resetScroll?: boolean;\n } = {}\n): (event: React.MouseEvent<E, MouseEvent>) => void {\n let navigate = useNavigate();\n let location = useLocation();\n let path = useResolvedPath(to);\n\n return React.useCallback(\n (event: React.MouseEvent<E, MouseEvent>) => {\n if (shouldProcessLinkClick(event, target)) {\n event.preventDefault();\n\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 explcitly set\n let replace =\n replaceProp !== undefined\n ? replaceProp\n : createPath(location) === createPath(path);\n\n navigate(to, { replace, state, resetScroll });\n }\n },\n [location, navigate, path, replaceProp, state, target, to, resetScroll]\n );\n}\n\n/**\n * A convenient wrapper for reading and writing search parameters via the\n * URLSearchParams interface.\n */\nexport function useSearchParams(defaultInit?: URLSearchParamsInit) {\n warning(\n typeof URLSearchParams !== \"undefined\",\n `You cannot use the \\`useSearchParams\\` hook in a browser that does not ` +\n `support the URLSearchParams API. If you need to support Internet ` +\n `Explorer 11, we recommend you load a polyfill such as ` +\n `https://github.com/ungap/url-search-params\\n\\n` +\n `If you're unsure how to load polyfills, we recommend you check out ` +\n `https://polyfill.io/v3/ which provides some recommendations about how ` +\n `to load polyfills only for users that need them, instead of for every ` +\n `user.`\n );\n\n let defaultSearchParamsRef = React.useRef(createSearchParams(defaultInit));\n\n let location = useLocation();\n let searchParams = React.useMemo(\n () =>\n getSearchParamsForLocation(\n location.search,\n defaultSearchParamsRef.current\n ),\n [location.search]\n );\n\n let navigate = useNavigate();\n let setSearchParams = React.useCallback(\n (\n nextInit: URLSearchParamsInit,\n navigateOptions?: { replace?: boolean; state?: any }\n ) => {\n navigate(\"?\" + createSearchParams(nextInit), navigateOptions);\n },\n [navigate]\n );\n\n return [searchParams, setSearchParams] as const;\n}\n\n/**\n * Submits a HTML `<form>` to the server without reloading the page.\n */\nexport interface SubmitFunction {\n (\n /**\n * Specifies the `<form>` to be submitted to the server, a specific\n * `<button>` or `<input type=\"submit\">` to use to submit the form, or some\n * arbitrary data to submit.\n *\n * Note: When using a `<button>` its `name` and `value` will also be\n * included in the form data that is submitted.\n */\n target:\n | HTMLFormElement\n | HTMLButtonElement\n | HTMLInputElement\n | FormData\n | URLSearchParams\n | { [name: string]: string }\n | null,\n\n /**\n * Options that override the `<form>`'s own attributes. Required when\n * submitting arbitrary data without a backing `<form>`.\n */\n options?: SubmitOptions\n ): void;\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 */\nexport function useSubmit(): SubmitFunction {\n return useSubmitImpl();\n}\n\nfunction useSubmitImpl(fetcherKey?: string): SubmitFunction {\n let router = React.useContext(UNSAFE_DataRouterContext);\n let defaultAction = useFormAction();\n\n return React.useCallback(\n (target, options = {}) => {\n invariant(\n router != null,\n \"useSubmit() must be used within a <DataRouter>\"\n );\n\n if (typeof document === \"undefined\") {\n throw new Error(\n \"You are calling submit during the server render. \" +\n \"Try calling submit within a `useEffect` or callback instead.\"\n );\n }\n\n let { method, encType, formData, url } = getFormSubmissionInfo(\n target,\n defaultAction,\n options\n );\n\n let href = url.pathname + url.search;\n let opts = {\n // If replace is not specified, we'll default to false for GET and\n // true otherwise\n replace:\n options.replace != null ? options.replace === true : method !== \"get\",\n formData,\n formMethod: method as FormMethod,\n formEncType: encType as FormEncType,\n };\n if (fetcherKey) {\n router.fetch(fetcherKey, href, opts);\n } else {\n router.navigate(href, opts);\n }\n },\n [defaultAction, router, fetcherKey]\n );\n}\n\nexport function useFormAction(action = \".\"): string {\n let routeContext = React.useContext(UNSAFE_RouteContext);\n invariant(routeContext, \"useFormAction must be used inside a RouteContext\");\n\n let [match] = routeContext.matches.slice(-1);\n let { pathname, search } = useResolvedPath(action);\n\n if (action === \".\" && match.route.index) {\n search = search ? search.replace(/^\\?/, \"?index&\") : \"?index\";\n }\n\n return pathname + search;\n}\n\nfunction createFetcherForm(fetcherKey: string) {\n let FetcherForm = React.forwardRef<HTMLFormElement, FormProps>(\n (props, ref) => {\n return <FormImpl {...props} ref={ref} fetcherKey={fetcherKey} />;\n }\n );\n if (__DEV__) {\n FetcherForm.displayName = \"fetcher.Form\";\n }\n return FetcherForm;\n}\n\nlet fetcherId = 0;\n\ntype FetcherWithComponents<TData> = Fetcher<TData> & {\n Form: ReturnType<typeof createFetcherForm>;\n submit: ReturnType<typeof useSubmitImpl>;\n load: (href: string) => void;\n};\n\n/**\n * Interacts with route loaders and actions without causing a navigation. Great\n * for any interaction that stays on the same page.\n */\nexport function useFetcher<TData = any>(): FetcherWithComponents<TData> {\n let router = React.useContext(UNSAFE_DataRouterContext);\n invariant(router, `useFetcher must be used within a DataRouter`);\n\n let [fetcherKey] = React.useState(() => String(++fetcherId));\n let [Form] = React.useState(() => createFetcherForm(fetcherKey));\n let [load] = React.useState(() => (href: string) => {\n invariant(router, `No router available for fetcher.load()`);\n router.fetch(fetcherKey, href);\n });\n let submit = useSubmitImpl(fetcherKey);\n\n let fetcher = router.getFetcher<TData>(fetcherKey);\n\n let fetcherWithComponents = React.useMemo(\n () => ({\n Form,\n submit,\n load,\n ...fetcher,\n }),\n [fetcher, Form, submit, load]\n );\n\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 fetcher available to clean up from useFetcher()\");\n return;\n }\n router.deleteFetcher(fetcherKey);\n };\n }, [router, fetcherKey]);\n\n return fetcherWithComponents;\n}\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 */\nexport function useFetchers(): Fetcher[] {\n let state = React.useContext(UNSAFE_DataRouterStateContext);\n invariant(state, `useFetchers must be used within a DataRouter`);\n return [...state.fetchers.values()];\n}\n\nconst SCROLL_RESTORATION_STORAGE_KEY = \"react-router-scroll-positions\";\nlet savedScrollPositions: Record<string, number> = {};\n\n/**\n * When rendered inside a DataRouter, will restore scroll positions on navigations\n */\nfunction useScrollRestoration({\n getKey,\n storageKey,\n}: {\n getKey?: GetScrollRestorationKeyFunction;\n storageKey?: string;\n} = {}) {\n let location = useLocation();\n let router = React.useContext(UNSAFE_DataRouterContext);\n let state = React.useContext(UNSAFE_DataRouterStateContext);\n\n invariant(\n router != null && state != null,\n \"useScrollRestoration must be used within a DataRouter\"\n );\n let { restoreScrollPosition, resetScrollPosition } = state;\n\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\n // Save positions on unload\n useBeforeUnload(\n React.useCallback(() => {\n if (state?.navigation.state === \"idle\") {\n let key =\n (getKey ? getKey(state.location, state.matches) : null) ||\n state.location.key;\n savedScrollPositions[key] = window.scrollY;\n }\n sessionStorage.setItem(\n storageKey || SCROLL_RESTORATION_STORAGE_KEY,\n JSON.stringify(savedScrollPositions)\n );\n window.history.scrollRestoration = \"auto\";\n }, [\n storageKey,\n getKey,\n state.navigation.state,\n state.location,\n state.matches,\n ])\n );\n\n // Read in any saved scroll locations\n React.useLayoutEffect(() => {\n try {\n let sessionPositions = sessionStorage.getItem(\n storageKey || SCROLL_RESTORATION_STORAGE_KEY\n );\n if (sessionPositions) {\n savedScrollPositions = JSON.parse(sessionPositions);\n }\n } catch (e) {\n // no-op, use default empty object\n }\n }, [storageKey]);\n\n // Enable scroll restoration in the router\n React.useLayoutEffect(() => {\n let disableScrollRestoration = router?.enableScrollRestoration(\n savedScrollPositions,\n () => window.scrollY,\n getKey\n );\n return () => disableScrollRestoration && disableScrollRestoration();\n }, [router, getKey]);\n\n // Restore scrolling when state.restoreScrollPosition changes\n React.useLayoutEffect(() => {\n // Explicit false means don't do anything (used for submissions)\n if (restoreScrollPosition === false) {\n return;\n }\n\n // been here before, scroll to it\n if (typeof restoreScrollPosition === \"number\") {\n window.scrollTo(0, restoreScrollPosition);\n return;\n }\n\n // try to scroll to the hash\n if (location.hash) {\n let el = document.getElementById(location.hash.slice(1));\n if (el) {\n el.scrollIntoView();\n return;\n }\n }\n\n // Opt out of scroll reset if this link requested it\n if (resetScrollPosition === false) {\n return;\n }\n\n // otherwise go to the top on new locations\n window.scrollTo(0, 0);\n }, [location, restoreScrollPosition, resetScrollPosition]);\n}\n\nfunction useBeforeUnload(callback: () => any): void {\n React.useEffect(() => {\n window.addEventListener(\"beforeunload\", callback);\n return () => {\n window.removeEventListener(\"beforeunload\", callback);\n };\n }, [callback]);\n}\n\n//#endregion\n\n////////////////////////////////////////////////////////////////////////////////\n//#region Utils\n////////////////////////////////////////////////////////////////////////////////\n\nfunction warning(cond: boolean, message: string): void {\n if (!cond) {\n // eslint-disable-next-line no-console\n if (typeof console !== \"undefined\") console.warn(message);\n\n try {\n // Welcome to debugging React Router!\n //\n // This error is thrown as a convenience so you can more easily\n // find the source for a warning that appears in the console by\n // enabling \"pause on exceptions\" in your JavaScript debugger.\n throw new Error(message);\n // eslint-disable-next-line no-empty\n } catch (e) {}\n }\n}\n//#endregion\n","import * as React from \"react\";\nimport type { Location, To } from \"history\";\nimport { Action, createPath, parsePath } from \"history\";\n\n// Get useHistory from react-router-dom v5 (peer dep).\n// @ts-expect-error\nimport { useHistory, Route as RouteV5 } from \"react-router-dom\";\n\n// We are a wrapper around react-router-dom v6, so bring it in\n// and bundle it because an app can't have two versions of\n// react-router-dom in its package.json.\nimport { Router, Routes, Route } from \"../react-router-dom\";\n\n// v5 isn't in TypeScript, they'll also lose the @types/react-router with this\n// but not worried about that for now.\nexport function CompatRoute(props: any) {\n let { path } = props;\n if (!props.exact) path += \"/*\";\n return (\n <Routes>\n <Route path={path} element={<RouteV5 {...props} />} />\n </Routes>\n );\n}\n\nexport function CompatRouter({ children }: { children: React.ReactNode }) {\n let history = useHistory();\n let [state, setState] = React.useState(() => ({\n location: history.location,\n action: history.action,\n }));\n\n React.useLayoutEffect(() => {\n history.listen((location: Location, action: Action) =>\n setState({ location, action })\n );\n }, [history]);\n\n return (\n <Router\n navigationType={state.action}\n location={state.location}\n navigator={history}\n >\n <Routes>\n <Route path=\"*\" element={children} />\n </Routes>\n </Router>\n );\n}\n\nexport interface StaticRouterProps {\n basename?: string;\n children?: React.ReactNode;\n location: Partial<Location> | string;\n}\n\n/**\n * A <Router> that may not navigate to any other location. This is useful\n * on the server where there is no stateful UI.\n */\nexport function StaticRouter({\n basename,\n children,\n location: locationProp = \"/\",\n}: StaticRouterProps) {\n if (typeof locationProp === \"string\") {\n locationProp = parsePath(locationProp);\n }\n\n let action = Action.Pop;\n let location: Location = {\n pathname: locationProp.pathname || \"/\",\n search: locationProp.search || \"\",\n hash: locationProp.hash || \"\",\n state: locationProp.state || null,\n key: locationProp.key || \"default\",\n };\n\n let staticNavigator = {\n createHref(to: To) {\n return typeof to === \"string\" ? to : createPath(to);\n },\n push(to: To) {\n throw new Error(\n `You cannot use navigator.push() on the server because it is a stateless ` +\n `environment. This error was probably triggered when you did a ` +\n `\\`navigate(${JSON.stringify(to)})\\` somewhere in your app.`\n );\n },\n replace(to: To) {\n throw new Error(\n `You cannot use navigator.replace() on the server because it is a stateless ` +\n `environment. This error was probably triggered when you did a ` +\n `\\`navigate(${JSON.stringify(to)}, { replace: true })\\` somewhere ` +\n `in your app.`\n );\n },\n go(delta: number) {\n throw new Error(\n `You cannot use navigator.go() on the server because it is a stateless ` +\n `environment. This error was probably triggered when you did a ` +\n `\\`navigate(${delta})\\` somewhere in your app.`\n );\n },\n back() {\n throw new Error(\n `You cannot use navigator.back() on the server because it is a stateless ` +\n `environment.`\n );\n },\n forward() {\n throw new Error(\n `You cannot use navigator.forward() on the server because it is a stateless ` +\n `environment.`\n );\n },\n };\n\n return (\n <Router\n basename={basename}\n children={children}\n location={location}\n navigationType={action}\n navigator={staticNavigator}\n static={true}\n />\n );\n}\n"],"names":["defaultMethod","defaultEncType","isHtmlElement","object","tagName","isButtonElement","toLowerCase","isFormElement","isInputElement","isModifiedEvent","event","metaKey","altKey","ctrlKey","shiftKey","shouldProcessLinkClick","target","button","createSearchParams","init","URLSearchParams","Array","isArray","Object","keys","reduce","memo","key","value","concat","map","v","getSearchParamsForLocation","locationSearch","defaultSearchParams","searchParams","has","getAll","forEach","append","getFormSubmissionInfo","defaultAction","options","method","action","encType","formData","submissionTrigger","getAttribute","FormData","name","type","form","Error","set","protocol","host","window","location","url","URL","BrowserRouter","basename","children","historyRef","React","useRef","current","createBrowserHistory","v5Compat","history","state","setState","useState","useLayoutEffect","listen","createElement","Router","navigationType","navigator","HashRouter","createHashHistory","HistoryRouter","displayName","Link","forwardRef","LinkWithRef","ref","onClick","reloadDocument","replace","to","resetScroll","rest","href","useHref","internalOnClick","useLinkClickHandler","handleClick","defaultPrevented","NavLink","NavLinkWithRef","ariaCurrentProp","caseSensitive","className","classNameProp","end","style","styleProp","path","useResolvedPath","match","useMatch","pathname","routerState","useContext","UNSAFE_DataRouterStateContext","nextLocation","navigation","nextPath","nextMatch","useMemo","matchPath","isPending","isActive","ariaCurrent","undefined","filter","Boolean","join","Form","props","FormImpl","forwardedRef","onSubmit","fetcherKey","submit","useSubmitImpl","formMethod","formAction","useFormAction","submitHandler","preventDefault","submitter","nativeEvent","currentTarget","replaceProp","navigate","useNavigate","useLocation","useCallback","createPath","useSearchParams","defaultInit","warning","defaultSearchParamsRef","search","setSearchParams","nextInit","navigateOptions","router","UNSAFE_DataRouterContext","invariant","document","opts","formEncType","fetch","routeContext","UNSAFE_RouteContext","matches","slice","route","index","cond","message","console","warn","e","CompatRoute","exact","Routes","Route","element","RouteV5","CompatRouter","useHistory","StaticRouter","locationProp","parsePath","Action","Pop","hash","staticNavigator","createHref","push","JSON","stringify","go","delta","back","forward","static"],"mappings":"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"}
File without changes
@@ -1,5 +1,5 @@
1
1
  /**
2
- * React Router DOM v5 Compat v6.4.0-pre.0
2
+ * React Router DOM v5 Compat v6.4.0-pre.4
3
3
  *
4
4
  * Copyright (c) Remix Software Inc.
5
5
  *
@@ -16,7 +16,7 @@ export { UNSAFE_NavigationContext, UNSAFE_LocationContext, UNSAFE_RouteContext,
16
16
  export interface DataBrowserRouterProps {
17
17
  children?: React.ReactNode;
18
18
  hydrationData?: HydrationState;
19
- fallbackElement: React.ReactElement;
19
+ fallbackElement?: React.ReactNode;
20
20
  routes?: RouteObject[];
21
21
  window?: Window;
22
22
  }
@@ -24,7 +24,7 @@ export declare function DataBrowserRouter({ children, fallbackElement, hydration
24
24
  export interface DataHashRouterProps {
25
25
  children?: React.ReactNode;
26
26
  hydrationData?: HydrationState;
27
- fallbackElement: React.ReactElement;
27
+ fallbackElement?: React.ReactNode;
28
28
  routes?: RouteObject[];
29
29
  window?: Window;
30
30
  }
@@ -89,7 +89,7 @@ export interface NavLinkProps extends Omit<LinkProps, "className" | "style" | "c
89
89
  style?: React.CSSProperties | ((props: {
90
90
  isActive: boolean;
91
91
  isPending: boolean;
92
- }) => React.CSSProperties);
92
+ }) => React.CSSProperties | undefined);
93
93
  }
94
94
  /**
95
95
  * A <Link> wrapper that knows if it's "active" or not.
@@ -152,9 +152,9 @@ export declare function useLinkClickHandler<E extends Element = HTMLAnchorElemen
152
152
  * URLSearchParams interface.
153
153
  */
154
154
  export declare function useSearchParams(defaultInit?: URLSearchParamsInit): readonly [URLSearchParams, (nextInit: URLSearchParamsInit, navigateOptions?: {
155
- replace?: boolean | undefined;
155
+ replace?: boolean;
156
156
  state?: any;
157
- } | undefined) => void];
157
+ }) => void];
158
158
  /**
159
159
  * Submits a HTML `<form>` to the server without reloading the page.
160
160
  */