From 4cb0fd942c7342a85277f7e8d284e1dfcc27fd07 Mon Sep 17 00:00:00 2001 From: Matt Brophy Date: Tue, 3 Jan 2023 17:16:02 -0500 Subject: [PATCH 1/2] Ensure consistent component tree for useId --- .changeset/three-ladybugs-clap.md | 6 +++ packages/react-router-dom/index.tsx | 1 - packages/react-router-dom/server.tsx | 28 ++++++-------- packages/react-router-native/index.tsx | 1 - packages/react-router/index.ts | 2 - packages/react-router/lib/components.tsx | 49 ++++++++++++++---------- packages/react-router/lib/context.ts | 8 +--- packages/react-router/lib/hooks.tsx | 12 ++++-- 8 files changed, 56 insertions(+), 51 deletions(-) create mode 100644 .changeset/three-ladybugs-clap.md diff --git a/.changeset/three-ladybugs-clap.md b/.changeset/three-ladybugs-clap.md new file mode 100644 index 0000000000..ae1b5177c9 --- /dev/null +++ b/.changeset/three-ladybugs-clap.md @@ -0,0 +1,6 @@ +--- +"react-router": patch +"react-router-dom": patch +--- + +Ensure useId consistency during SSR diff --git a/packages/react-router-dom/index.tsx b/packages/react-router-dom/index.tsx index 831ae90c96..cf0fd14240 100644 --- a/packages/react-router-dom/index.tsx +++ b/packages/react-router-dom/index.tsx @@ -178,7 +178,6 @@ export { export { UNSAFE_DataRouterContext, UNSAFE_DataRouterStateContext, - UNSAFE_DataStaticRouterContext, UNSAFE_NavigationContext, UNSAFE_LocationContext, UNSAFE_RouteContext, diff --git a/packages/react-router-dom/server.tsx b/packages/react-router-dom/server.tsx index 041d09c07c..a8ac8cb10c 100644 --- a/packages/react-router-dom/server.tsx +++ b/packages/react-router-dom/server.tsx @@ -27,7 +27,6 @@ import { Router, UNSAFE_DataRouterContext as DataRouterContext, UNSAFE_DataRouterStateContext as DataRouterStateContext, - UNSAFE_DataStaticRouterContext as DataStaticRouterContext, UNSAFE_enhanceManualRouteObjects as enhanceManualRouteObjects, } from "react-router-dom"; @@ -98,6 +97,7 @@ export function StaticRouterProvider({ router, navigator: getStatelessNavigator(), static: true, + staticContext: context, basename: context.basename || "/", }; @@ -119,22 +119,18 @@ export function StaticRouterProvider({ return ( <> - - - + + - - - - - - + + + + {hydrateScript ? (