-
Notifications
You must be signed in to change notification settings - Fork 152
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Re-Export RouterContext for more control #413
base: main
Are you sure you want to change the base?
Conversation
🦋 Changeset detectedLatest commit: 8f0a8c3 The changes in this PR will be included in the next version bump. This PR includes changesets to release 1 package
Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
Thanks. I agree this functionality is needed but I need to decide on the exposed API. To that end since this request is for preloading.. I've worked on making the API more extensible for the future and feel comfortable exporting it now. There will be a new method in the next release. |
Having access to the router context would make it easier for third party libraries to interact with the router as well. In Sentry's case, we export a HOC to wrap |
Yeah I get that. The problem right now is none of the APIs here are designed particularly well to be public facing. Like the implementation of export const useBeforeLeave = (listener: (e: BeforeLeaveEventArgs) => void) => {
const s = useRouter().beforeLeave.subscribe({
listener,
location: useLocation(),
navigate: useNavigate()
});
onCleanup(s);
}; It's using other router properties in its subscribe method which is weird since it could be encapsulated. I haven't really had the chance to evaluate all of these. Not to mention any other future extensions. One thing is for certain the moment we expose this, we are on the hook for the internal API. |
@ryansolid I sympathize with your concerns about exposing the API. However right now this is giving us fits, as we can see no reliable way to determine the current route, or access its metadata. This seems like very basic functionality. We use config-based routing, and have additional metadata in the route object that we desperately need to set up the page. There are no good work-arounds that we can see. Looking up the route by path won't work. For one thing, we can't rely on the path at all until the route stabilizes (cf. The router has Moreover, we do not understand why all the 'primitives' return function generators, 'reactive objects' (whatever those are), or signals (ok, we do know what those are), and why some return one rather than the other. In many cases, we just need the value once, right now, whatever it is, without having to worry about callbacks, memos, or whether something will be called repeatedly later on, creating unintended effects. Do we use We don't want to hook into an undocumented API, but we're reaching a very high level of furstration here. Is there any hope of getting this sorted out any time soon? |
The problem
I develop a PWA mobile-first application based on solid start.
I liked the prefetch behaviour while debugging the app in my laptop environment, so when you hover any link, the resources of that route are being downloaded, so no FUOC happens when you click the link.
However, when I tested the app on my phone, I noticed the flash of unstyled content instantly.
First approach
As first approach after looking through the code of solid router, I tried to emulate mouseover event on page load, for all the links found onMount. However, I see it as a big mistake
Proposed solution
I recommend to re-export the context, as it has all the neccessary data and methods to programmatically preload routes, instead of making another bad solution.