Last active
February 11, 2021 19:59
-
-
Save ryanflorence/2c50e77768e3f88b1c7251ef95ed01d3 to your computer and use it in GitHub Desktop.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// If the user has been on the page for over 12 hours, the next link | |
// click will do a full page transition to get new code | |
import React from "react"; | |
import { BrowserRouter, useLocation } from "react-router-dom"; | |
let hour = 3600000; | |
export default function StaleAppRouter(props) { | |
let [isStale, setIsStale] = useState(false); | |
useEffect(() => { | |
let id = setTimeout(() => { | |
setIsStale(true) | |
}, hour * 12) | |
return () => clearTimeout(id) | |
}, []); | |
return <BrowserRouter forceRefresh={isStale} /> | |
} | |
// now replace your <BrowserRouter /> with a <StaleAppRouter /> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
It seems that modifying
forceRefresh
after initialization is unsupported. Has anyone had success with the examples here?Comment from Michael on the prop:
remix-run/history#477 (comment)
BrowserRouter
source (history
is never reinitialized):https://github.com/ReactTraining/react-router/blob/346153e38365e6a88657ce2e4e5acada290fc430/packages/react-router-dom/modules/BrowserRouter.js#L10-L16
The suggested solution looks to be using
key
, but that would result in a full remount of the app tree belowRouter
, which is (probably) undesirable.