query icon indicating copy to clipboard operation
query copied to clipboard

feat(devtools): enable setting loading/error via devtools

Open paul-sachs opened this issue 3 years ago • 1 comments

Allows the devtools to toggle loading and errors states (at least until the next fetch is triggered).

Things to do:

  • [ ] Make sure onError get's triggered

https://user-images.githubusercontent.com/11449728/197222942-bc22a1ae-0ecf-476f-8ad8-d741267a708d.mov

paul-sachs avatar Oct 21 '22 14:10 paul-sachs

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 a4ff17eb7f27b1c1c05337334a5652a4453b7184:

Sandbox Source
@tanstack/query-example-react-basic-typescript Configuration
@tanstack/query-example-solid-basic-typescript Configuration
@tanstack/query-example-svelte-basic Configuration
@tanstack/query-example-vue-basic Configuration

codesandbox-ci[bot] avatar Oct 21 '22 14:10 codesandbox-ci[bot]

Codecov Report

Base: 91.84% // Head: 92.16% // Increases project coverage by +0.31% :tada:

Coverage data is based on head (356e26e) compared to base (48e806b). Patch coverage: 97.56% of modified lines in pull request are covered.

:mega: 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              
Impacted Files Coverage Δ
packages/query-core/src/query.ts 99.02% <ø> (ø)
...kages/react-query-devtools/src/styledComponents.ts 92.85% <ø> (ø)
packages/react-query-devtools/src/devtools.tsx 89.09% <97.56%> (+5.16%) :arrow_up:

Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here.

:umbrella: View full report at Codecov.
:loudspeaker: Do you have feedback about the report comment? Let us know in this issue.

codecov-commenter avatar Jan 23 '23 12:01 codecov-commenter

@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:

  • some tests of the new behaviour
  • a way to make the loading state revert back when clicking the button a second time, and maybe some visual feedback that we are now in loading state (similar to what the offline toggle button does)

would you like to continue contributing this?

TkDodo avatar Jan 23 '23 12:01 TkDodo

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.

paul-sachs avatar Jan 23 '23 15:01 paul-sachs

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 resetQueries approach that you've already taken for the error state. But the only way to get out of the loading state right now is to click refetch, and I think it would be good if the button behaved like a toggle. Alternatively, we could keep the last state in a ref before overwriting it and then restore it maybe?

TkDodo avatar Jan 23 '23 15:01 TkDodo

I'd worry what would happen if something toggles loading state during loading. I'm not sure how setState works internally, don't know if it will abort the on going promise. Feels a little like reset is our safest bet. Either way really, the toggle behaviour makes sense.

paul-sachs avatar Jan 23 '23 15:01 paul-sachs

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.

paul-sachs avatar Jan 23 '23 15:01 paul-sachs

Was hoping to do something like:

activeQuery.fetch({
  queryFn: () => new Promise((resolve, reject) => {}),
  cacheTime: -1,
})

But i don't think that's replacing the queryFn like I thought it would. It triggers a refetch of the existing queryFn...

paul-sachs avatar Jan 23 '23 15:01 paul-sachs

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...

paul-sachs avatar Jan 23 '23 16:01 paul-sachs

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.

paul-sachs avatar Jan 23 '23 16:01 paul-sachs

@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.

paul-sachs avatar Jan 23 '23 19:01 paul-sachs

The latest updates on your projects. Learn more about Vercel for Git ↗︎

1 Ignored Deployment
Name Status Preview Comments Updated
query ⬜️ Ignored (Inspect) Mar 15, 2023 at 8:09AM (UTC)

vercel[bot] avatar Jan 26 '23 05:01 vercel[bot]

Alright, finally got to fixing prettier + lint issues.

paul-sachs avatar Feb 01 '23 15:02 paul-sachs

Thanks for this ❤️ there are still some rough edges, like:

  • trigger loading
  • trigger error
  • restore error
  • restore loading --> now nothing happens 🤷

I still think this is good enough and we could tackle this in follow-ups. Maybe we shouldn't have two buttons after all, but just one option that puts the query into a certain "state", either loading or error, and one reset that just puts it back to avoid having to tackle multiple states?

TkDodo avatar Feb 12 '23 14:02 TkDodo

@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!

paul-sachs avatar Mar 16 '23 20:03 paul-sachs