Open renovate[bot] opened 4 months ago
Name | Link |
---|---|
Latest commit | 914162b4b6531354a06c806e69c9e5aab232c8b0 |
Latest deploy log | https://app.netlify.com/sites/nonebot-bison/deploys/6748e551d3d6750008f4f3cc |
Deploy Preview | https://deploy-preview-592--nonebot-bison.netlify.app |
Preview on mobile | Toggle QR Code...Use your smartphone camera to open QR code link. |
To edit notification comments on pull requests, go to your Netlify site configuration.
All modified and coverable lines are covered by tests :white_check_mark:
Project coverage is 85.25%. Comparing base (
630845f
) to head (914162b
).
:umbrella: View full report in Codecov by Sentry.
:loudspeaker: Have feedback on the report? Share it here.
This PR contains the following updates:
^1.9.7
->^2.4.0
Release Notes
reduxjs/redux-toolkit (@reduxjs/toolkit)
### [`v2.4.0`](https://redirect.github.com/reduxjs/redux-toolkit/releases/tag/v2.4.0) [Compare Source](https://redirect.github.com/reduxjs/redux-toolkit/compare/v2.3.0...v2.4.0) This **feature release** includes multiple tweaks and fixes to RTK Query functionality, additional exported TS types, and drops support for TS versions earlier than 5.0. #### Changelog ##### RTK Query Improvements Lazy query hooks can now be reset. `retry.fail` now accepts `meta` as a second argument. Tag invalidation arrays now ignore nullish values. We did some small internal refactoring around Maps and default values that shrank bundle size slightly. ##### RTK Query Bugfixes Passing `skipToken` to a query hook now bails out before running any other logic, which fixes cases where `serializeQueryArgs` previously threw an error because there were no args to process. The `autoBatchEnhancer` now reads `window.requestAnimationFrame` later, which it to work properly with Jest fake timers. We fixed cases where the hook result `isSuccess` flag would briefly flicker to `false` when switched to a different cache entry that was uninitialized, and would briefly flicker to `true` when refetching a query that previously errored. ##### Additional TS Types We now export `Typed[Query|Mutation]OnQueryStarted` helpers to let you define `onQueryStarted` callbacks outside of `createApi` if desired. We also now export a `CreateAsyncThunkFunction` type that can be used to type userland wrappers around `createAsyncThunk`. ##### TS Support Matrix Updates We've historically tried to maintain TS backwards compatibility as long as possible, and made occasional updates to our TS support matrix in minor versions over time. As of RTK 2.3.0, we officially supported back through TS 4.7. As of this release, we're tweaking that support policy to match [the policy used by DefinitelyTyped](https://redirect.github.com/DefinitelyTyped/DefinitelyTyped?tab=readme-ov-file#support-window): > Definitely Typed only tests packages on versions of TypeScript that are less than 2 years old > ![image](https://redirect.github.com/user-attachments/assets/30c8c1e6-db37-4ef1-a323-1c935fe4a12d) Given that, **we've dropped official support for TS versions earlier than 5.0**. (RTK *may* work with those versions, but we no longer test against them and won't try to fix issues with those versions.) We'll continue to update our TS support matrix over time based on that 2-year rolling window. #### What's Changed - add example to reproduce defect of serializeQueryArgs with skipToken by [@Themezv](https://redirect.github.com/Themezv) in [https://github.com/reduxjs/redux-toolkit/pull/4708](https://redirect.github.com/reduxjs/redux-toolkit/pull/4708) - Read `window.rAF` later to allow fake timers to work correctly by [@ensconced](https://redirect.github.com/ensconced) in [https://github.com/reduxjs/redux-toolkit/pull/4701](https://redirect.github.com/reduxjs/redux-toolkit/pull/4701) - Add type helpers for `OnQueryStarted` callbacks by [@aryaemami59](https://redirect.github.com/aryaemami59) in [https://github.com/reduxjs/redux-toolkit/pull/4713](https://redirect.github.com/reduxjs/redux-toolkit/pull/4713) - Add a type for `createAsyncThunk` without the `withTypes` method by [@EskiMojo14](https://redirect.github.com/EskiMojo14) in [https://github.com/reduxjs/redux-toolkit/pull/4667](https://redirect.github.com/reduxjs/redux-toolkit/pull/4667) - Add ability to reset lazy query hooks by [@alexmotoc](https://redirect.github.com/alexmotoc) in [https://github.com/reduxjs/redux-toolkit/pull/4689](https://redirect.github.com/reduxjs/redux-toolkit/pull/4689) - Ignore nullish values in tag invalidations by [@pierroberto](https://redirect.github.com/pierroberto) in [https://github.com/reduxjs/redux-toolkit/pull/4671](https://redirect.github.com/reduxjs/redux-toolkit/pull/4671) - Allow passing meta to retry.fail, and passing baseQuery to ensure types match by [@EskiMojo14](https://redirect.github.com/EskiMojo14) in [https://github.com/reduxjs/redux-toolkit/pull/4723](https://redirect.github.com/reduxjs/redux-toolkit/pull/4723) - Keep `isSuccess: true` when switching to an uninitialized cache entry by [@markerikson](https://redirect.github.com/markerikson) in [https://github.com/reduxjs/redux-toolkit/pull/4731](https://redirect.github.com/reduxjs/redux-toolkit/pull/4731) - Keep `isSuccess` consistent when refetching after an error by [@markerikson](https://redirect.github.com/markerikson) in [https://github.com/reduxjs/redux-toolkit/pull/4732](https://redirect.github.com/reduxjs/redux-toolkit/pull/4732) - Update to new version of upsert proposal, and fix listener equality checks by [@EskiMojo14](https://redirect.github.com/EskiMojo14) in [https://github.com/reduxjs/redux-toolkit/pull/4735](https://redirect.github.com/reduxjs/redux-toolkit/pull/4735) **Full Changelog**: https://github.com/reduxjs/redux-toolkit/compare/v2.3.0...v2.4.0 ### [`v2.3.0`](https://redirect.github.com/reduxjs/redux-toolkit/releases/tag/v2.3.0) [Compare Source](https://redirect.github.com/reduxjs/redux-toolkit/compare/v2.2.8...v2.3.0) This **feature release** adds a new RTK Query `upsertQueryEntries` util to batch-upsert cache entries more efficiently, passes through additional values for use in `prepareHeaders`, and exports additional TS types around query options and selectors. #### Changelog ##### `upsertQueryEntries` RTK Query already had an `upsertQueryData` thunk that would upsert a single cache entry. However, some users wanted to upsert *many* cache entries (potentially hundreds or thousands), and found that `upsertQueryData` had poor performance in those cases. This is because `upsertQueryData` runs the full async request handling sequence, including dispatching both `pending` and `fulfilled` actions, each of which run the main reducer and update store subscribers. That means there's `2N` store / UI updates per item, so upserting hundreds of items becomes extremely perf-intensive. RTK Query now includes an `api.util.upsertQueryEntries` action that is meant to handle the batched upsert use case more efficiently. It's a single synchronous action that accepts an array of many `{endpointName, arg, value}` entries to upsert. This results in a single store update, making this vastly better for performance vs many individual `upsertQueryData` calls. We see this as having two main use cases. The first is prefilling the cache with data retrieved from storage on app startup (and it's worth noting that `upsertQueryEntries` can accept entries for many different endpoints as part of the same array). The second is to act as a "pseudo-normalization" tool. [RTK Query is *not* a "normalized" cache](https://redux-toolkit.js.org/rtk-query/usage/cache-behavior#no-normalized-or-de-duplicated-cache). However, there are times when you may want to prefill other cache entries with the contents of another endpoint, such as taking the results of a `getPosts` list endpoint response and prefilling the individual `getPost(id)` endpoint cache entries, so that components that reference an individual item endpoint already have that data available. Currently, you can implement the "pseudo-normalization" approach by dispatching `upsertQueryEntries` in an endpoint lifecycle, like this: ```ts const api = createApi({ endpoints: (build) => ({ getPosts: build.queryConfiguration
📅 Schedule: Branch creation - "before 4am on Monday" (UTC), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.