-
-
Notifications
You must be signed in to change notification settings - Fork 3.2k
feat(devtools): enable setting loading/error via devtools #4352
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
feat(devtools): enable setting loading/error via devtools #4352
Conversation
This pull request is automatically built and testable in CodeSandbox. To see build info of the built libraries, click here or the icon next to each commit SHA. Latest deployment of this branch, based on commit a4ff17e:
|
Codecov ReportBase: 91.84% // Head: 92.16% // Increases project coverage by
📣 This organization is not using Codecov’s GitHub App Integration. We recommend you install it so Codecov can continue to function properly for your repositories. Learn more Additional details and impacted files@@ Coverage Diff @@
## main #4352 +/- ##
==========================================
+ Coverage 91.84% 92.16% +0.31%
==========================================
Files 111 111
Lines 4146 4187 +41
Branches 1072 1087 +15
==========================================
+ Hits 3808 3859 +51
+ Misses 317 307 -10
Partials 21 21
Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. ☔ View full report at Codecov. |
@paul-sachs thanks for this PR, and sorry that it went unnoticed for a while. I've fixed some issues and did a bit of refactoring. What would be missing from my perspective would be:
would you like to continue contributing this? |
Hi @TkDodo I'll take a look for sure. I'll need to familiarize myself with the testing setup but that should be fine. Storing the previous state is a little tricky if I remember correctly. I think we can have it retrigger the query to restore behaviour. Either way, I'll look into it. |
That's fine - I like the |
I'd worry what would happen if something toggles loading state during loading. I'm not sure how |
So I've fixed the toggle state, however this approach doesn't seem to work in suspense mode since the setState doesn't trigger a promise... This will need something else to work through that issue. |
Was hoping to do something like: activeQuery.fetch({
queryFn: () => new Promise((resolve, reject) => {}),
cacheTime: -1,
}) But i don't think that's replacing the |
Ah no, i was incorrect. It is using the updated queryFn. At least, I think it is. The problem is trying to store the previous queryFn so I can restore it... |
Alright, managed to get suspense working. Had to store some query state inside queryMeta so not sure I feel great about that, but it does keep query state all together. Maybe there's a better place to store it? Next, I'll take a look at the testing infrastructure to figure out how to write some tests. |
@TkDodo Tests are up and green. I've represented the current state of the query in the buttons themselves but let me know if you want a totally different direction. |
The latest updates on your projects. Learn more about Vercel for Git ↗︎ 1 Ignored Deployment
|
Alright, finally got to fixing prettier + lint issues. |
* chore: extract package validation to an extra script and run it during CI * chore: add missing `build:types` script to solid-query
* docs: update link for v2 docs * Update README.md --------- Co-authored-by: Dominik Dorfmeister <office@dorfmeister.cc>
…k#5063) Do not stretch query status label (fresh, fetching, paused, stale, inactive) shown on Query Details view.
…anStack#5041) Co-authored-by: Dominik Dorfmeister <office@dorfmeister.cc>
Co-authored-by: Dominik Dorfmeister <office@dorfmeister.cc>
…utationCache (TanStack#5075) * feat(query-core): Add global onSettled callbacks for QueryCache and MutationCache * test: tests for query onSettled callback * test: tests for mutation onSettled callback * docs: onSettled callbacks
this fixes an issue around stale closures where callbacks are not updated, thus are called with wrong values in the closure
* fix(eslint-plugin): improve object property checks * prettier
* adding quick caching test * reverting workflow change * updating pr yml to test nx speed * fixing yml on property * fixing yml on property * fixing target name * upping to running4 in parallel * upping to running 5 in parallel * upping to running 6 in parallel * upping to running 7 in parallel * upping to running 8 in parallel * upping to running 9 in parallel * upping to running 10 in parallel * opting for --parallel=5 * cleaning up nx.json * revert touching of ci.yml file * reverting on property of pr.yml file * updating root pacakge.json test:lib command * fixing frozen lockfile error in ci --------- Co-authored-by: Dominik Dorfmeister <office@dorfmeister.cc>
* chore: include scripts directory in linting and fix issues * chore: add missing dependencies chalk and semver
@TkDodo My apologies for letting this drop off. I'll submit a follow on PR with the suggested changes. Thanks so much for merging this, it'll make modifying loading states so much easier! |
Allows the devtools to toggle loading and errors states (at least until the next fetch is triggered).
Things to do:
onError
get's triggeredScreen.Recording.2022-10-21.at.10.41.06.AM.mov