redux-eggs
redux-eggs copied to clipboard
chore(deps): update dependency @reduxjs/toolkit to v1.8.5
This PR contains the following updates:
Package | Change | Age | Adoption | Passing | Confidence |
---|---|---|---|---|---|
@reduxjs/toolkit (source) | 1.7.2 -> 1.8.5 |
Release Notes
reduxjs/redux-toolkit
v1.8.5
This bugfix releas fixes an issue with large keepUnusedDataFor
values overflowing JS timers, exports the types for the Redux DevTools Extension option, and and improves behavior of URL string generation.
Changelog
keepUnusedDataFor
Timer Fix
keepUnusedDataFor
accepts a value in seconds. When there are no more active subscriptions for a piece of data, RTKQ will set a timer using setTimeout
, and keepUnusedDataFor * 1000
as the timer value.
We've been advising users that if they want to keep data in the cache forever that they should use a very large value for keepUnusedDataFor
, such as 10 years in seconds.
However, it turns out that JS engines use a 32-bit signed int for timers, and 32-bits in milliseconds is only 24.8 days. If a timer is given a value larger than that, it triggers immediately.
We've updated the internal logic to clamp the keepUnusedDataFor
value to be between 0 and THIRTY_TWO_BIT_MAX_TIMER_SECONDS - 1
.
Note that in RTK 1.9 (coming soon), RTKQ will also accept Infinity
as a special keepUnusedDataFor
value to indicate cached data should never be expired.
Other Changes
RTK inlines the TS types for the Redux DevTools Extension options to avoid an extra dependency, but the TS type for the options object wasn't exported publicly. We now export the DevToolsEnhancerOptions
type.
The logic for generating a final URL has been updated to avoid adding an extra trailing /
.
What's Changed
- Prevent
keepUnusedDataFor
values from overflowingsetTimeout
counter by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2595 - remove typeof undefined checks where not necessary 🐃🪒 by @phryneas in https://github.com/reduxjs/redux-toolkit/pull/1726
- Update RDT options types, and export those + AnyListenerPredicate by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2596
- Ensures there is no unexpected slash in url before query params by @ygrishajev in https://github.com/reduxjs/redux-toolkit/pull/2470
Full Changelog: https://github.com/reduxjs/redux-toolkit/compare/v1.8.4...v1.8.5
v1.8.4
This bugfix release adds exported TS types for RTKQ hooks for use in wrapping logic, adds useDebugValue
to the hooks to improve display in the React DevTools, updates the inlined types for the Redux DevTools options, and fixes an issue in createEntityAdapter
that could result in duplicate IDs being stored.
Changelog
RTKQ Hook Result Types
RTK's types heavily rely on inference to minimize the amount of type info users have to provide. However, this can also make it difficult to write functions that wrap calls to RTK APIs.
Some users have asked to have types that help them write "higher-order hooks". RTK now exports types that represent "the return object for a query/mutation hook with a given value": TypedUseQueryHookResult
and TypedUseMutationResult
. Both require <ResultType, QueryArg, BaseQuery>
as generics, like this:
const baseQuery = fetchBaseQuery({url: "https://some.server"});
type CustomHookResult = TypedUseQueryHookResult<MyResultObject, MyArgObject, typeof baseQuery>
const useMyCustomHook = (arg: MyArgObject) : CustomHookResult => {
return api.useGetSomeDataQuery(arg);
}
Redux DevTools Options Fixes
As of Redux DevTools 3.0, some of field names for custom DevTools options have changed to actionsAllowlist
and actionsDenylist
. Since we inline the types instead of having a separate dependency, we've updated our TS types to match that. No runtime behavior was changed.
Other Changes
RTKQ hooks now use useDebugValue
to give a better preview of the current value in the React DevTools "Component" tab.
The <ApiProvider>
component now does a better job of registering and cleaning up focus listeners.
Fixed a bug with createEntityAdapter
that could allow duplicate IDs to be added depending on update parameters.
What's Changed
- fix: prevent duplicate ids when updating id of an element with the id of an existing element by @samatar26 in https://github.com/reduxjs/redux-toolkit/pull/2020
- ApiProvider: correctly register listeners, allow to disable listeners by @phryneas in https://github.com/reduxjs/redux-toolkit/pull/2277
- Update devtools options TS types based on RDT 3.0 by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2480
- fix: typo in unhandled error message by @MichielTondeur in https://github.com/reduxjs/redux-toolkit/pull/2538
- Use useDebugValue in useQuery and useMutation hooks by @kaankeskin in https://github.com/reduxjs/redux-toolkit/pull/2500
- add types for manually typing hook results in userland code by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2580
Full Changelog: https://github.com/reduxjs/redux-toolkit/compare/v1.8.3...v1.8.4
v1.8.3
This bugfix release fixes a few minor issues and bits of behavior, including updating the React-Redux peer dep to ^8.0.2
final, stable sorting in createEntityAdapter.updateMany
and some initial state handling in createSlice
.
Changelog
React-Redux Peer Dep
We'd previously published an RTK build that accepted React-Redux v8 beta as a peer dep (for use with RTK Query). Since React-Redux v8 is out now, we've updated the peer dep to ^8.0.2
.
Entity Adapter Updates
Previously, applying updates via createEntityAdapter.updateMany
caused sorting order to change. Entities that had the same sorting result should have stayed in the same order relative to each other, but if one of those items had any updates, it would sort to the back of that group. This was due to items being removed from the lookup table and re-added, and since JS engines iterate keys in insertion order, the updated item would now end up compared later than before.
We've reworked the implementation of updateMany
to avoid that. This also ended up fixing another issue where multiple update entries targeting the same item ID would only have the first applied.
createSlice
Initial State
createSlice
now logs an error if initialState
is undefined
. This is most commonly seen when users misspell initialState
. It also has better handling for values that can't be frozen by Immer such as primitives.
RTK Query
Several assorted improvements, including TS types for BaseQuery
and checking if the body can actually be safely stringified.
What's Changed
- Add Missing Else to enhanceEndpoints Function by @kinson in https://github.com/reduxjs/redux-toolkit/pull/2386
- Check initial state is draftable before using immer to freeze it. by @EskiMojo14 in https://github.com/reduxjs/redux-toolkit/pull/2378
- Check that body isJsonifiable before stringify by @ShaunDychko in https://github.com/reduxjs/redux-toolkit/pull/2330
- Respect BaseQuery meta types when enhancing by @TamasSzigeti in https://github.com/reduxjs/redux-toolkit/pull/2225
- Throw new error when initial state is undefined by @dannielss in https://github.com/reduxjs/redux-toolkit/pull/2461
- Rewrite
updateMany
to ensure stable sorting order by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2464 - Bump React-Redux peer dep by @markerikson in https://github.com/reduxjs/redux-toolkit/commit/3033a33c3dd2ad743f02a44603bc77174599eebc
New Contributors
Full Changelog: https://github.com/reduxjs/redux-toolkit/compare/v1.8.2...1.8.3
v1.8.2
This bugfix release fixes a minor issue where calling listenerMiddleware.startListening()
multiple times with the same effect
callback reference would result in multiple entries being added. The correct behavior is that only the first entry is added, and later attempts to add the same effect callback reference just return the existing entry.
What's Changed
- Add type @remarks for configureStore's middleware by @msutkowski in https://github.com/reduxjs/redux-toolkit/pull/2252
- Fix the "map values transpilation" bug, in yet another place by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2351
Full Changelog: https://github.com/reduxjs/redux-toolkit/compare/v1.8.1...v1.8.2
v1.8.1
This release updates RTK's peer dependencies to accept React 18 as a valid version. This should fix installation errors caused by NPM's "install all the peer deps and error if they don't match" behavior.
React-Redux and React 18
Note: If you are now using React 18, we strongly recommend using the React-Redux v8 beta instead of v7.x!. v8 has been rewritten internally to work correctly with React 18's Concurrent Rendering capabilities. React-Redux v7 will run and generally work okay with existing code, but may have rendering issues if you start using Concurrent Rendering capabilities in your code.
Now that React 18 is out, we plan to finalize React-Redux v8 and release it live within the next couple weeks. We would really appreciate final feedback on using React-Redux v8 beta with React 18 before we publish the final version.
v1.8.0
This release adds the new "listener" middleware, updates configureStore
's types to better handle type inference from middleware that override dispatch
return values, and updates our TS support matrix to drop support for TS < 4.1.
Changelog
New "Listener" Side Effects Middleware
RTK has integrated the thunk middleware since the beginning. However, thunks are imperative functions, and do not let you run code in response to dispatched actions. That use case has typically been covered with libraries like redux-saga
(which handles side effects with "sagas" based on generator functions), redux-observable
(which uses RxJS observables), or custom middleware.
We've added a new "listener" middleware to RTK to cover that use case. The listener middleware is created using createListenerMiddleware()
, and lets you define "listener" entries that contain an "effect" callback with additional logic and a way to specify when that callback should run based on dispatched actions or state changes.
Conceptually, you can think of this as being similar to React's useEffect
hook, except that it runs logic in response to Redux store updates instead of component props/state updates.
The listener middleware is intended to be a lightweight alternative to more widely used Redux async middleware like sagas and observables. While similar to thunks in level of complexity and concept, it can replicate some common saga usage patterns. We believe that the listener middleware can be used to replace most of the remaining use cases for sagas, but with a fraction of the bundle size and a much simpler API.
Listener effect callbacks have access to dispatch
and getState
, similar to thunks. The listener also receives a set of async workflow functions like take
, condition
, pause
, fork
, and unsubscribe
, which allow writing more complex async logic.
Listeners can be defined statically by calling listenerMiddleware.startListening()
during setup, or added and removed dynamically at runtime with special dispatch(addListener())
and dispatch(removeListener())
actions.
The API reference is available at:
https://redux-toolkit.js.org/api/createListenerMiddleware
Huge thanks to @FaberVitale for major contributions in refining the middleware API and implementing key functionality.
Basic usage of the listener middleware looks like:
import { configureStore, createListenerMiddleware } from '@​reduxjs/toolkit'
import todosReducer, {
todoAdded,
todoToggled,
todoDeleted,
} from '../features/todos/todosSlice'
// Create the middleware instance and methods
const listenerMiddleware = createListenerMiddleware()
// Add one or more listener entries that look for specific actions.
// They may contain any sync or async logic, similar to thunks.
listenerMiddleware.startListening({
actionCreator: todoAdded,
effect: async (action, listenerApi) => {
// Run whatever additional side-effect-y logic you want here
console.log('Todo added: ', action.payload.text)
// Can cancel other running instances
listenerApi.cancelActiveListeners()
// Run async logic
const data = await fetchData()
// Pause until action dispatched or state changed
if (await listenerApi.condition(matchSomeAction)) {
// Use the listener API methods to dispatch, get state,
// unsubscribe the listener, start child tasks, and more
listenerApi.dispatch(todoAdded('Buy pet food'))
listenerApi.unsubscribe()
}
},
})
const store = configureStore({
reducer: {
todos: todosReducer,
},
// Add the listener middleware to the store.
// NOTE: Since this can receive actions with functions inside,
// it should go before the serializability check middleware
middleware: (getDefaultMiddleware) =>
getDefaultMiddleware().prepend(listenerMiddleware.middleware),
})
You can use it to write more complex async workflows, including pausing the effect callback until a condition check resolves, and forking "child tasks" to do additional work:
// Track how many times each message was processed by the loop
const receivedMessages = {
a: 0,
b: 0,
c: 0,
}
const eventPollingStarted = createAction('serverPolling/started')
const eventPollingStopped = createAction('serverPolling/stopped')
listenerMiddleware.startListening({
actionCreator: eventPollingStarted,
effect: async (action, listenerApi) => {
// Only allow one instance of this listener to run at a time
listenerApi.unsubscribe()
// Start a child job that will infinitely loop receiving messages
const pollingTask = listenerApi.fork(async (forkApi) => {
try {
while (true) {
// Cancellation-aware pause for a new server message
const serverEvent = await forkApi.pause(pollForEvent())
// Process the message. In this case, just count the times we've seen this message.
if (serverEvent.type in receivedMessages) {
receivedMessages[
serverEvent.type as keyof typeof receivedMessages
]++
}
}
} catch (err) {
if (err instanceof TaskAbortError) {
// could do something here to track that the task was cancelled
}
}
})
// Wait for the "stop polling" action
await listenerApi.condition(eventPollingStopped.match)
pollingTask.cancel()
},
})
configureStore
Middleware Type Improvements
Middleware can override the default return value of dispatch
. configureStore
tries to extract any declared dispatch
type overrides from the middleware
array, and uses that to alter the type of store.dispatch
.
We identified some cases where the type inference wasn't working well enough, and rewrote the type behavior to be more correct.
TypeScript Support Matrix Updates
RTK now requires TS 4.1 or greater to work correctly, and we've dropped 4.0 and earlier from our support matrix.
Other Changes
The internal logic for the serializability middleware has been reorganized to allow skipping checks against actions, while still checking values in the state.
What's Changed
Since most of the implementation work on the middleware was done over the last few months, this list only contains the most recent PRs since 1.7.2. For details on the original use case discussions and the evolution of the middleware API over time, see:
- RTK issue #237: Add an action listener middleware
- RTK PR #547: yet another attempt at an action listener middleware
- RTK discussion #1648: New experimental "action listener middleware" package available
PRs since 1.7.2:
- Rewrite MiddlewareArray and gDM for better Dispatch inference by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2001
- Change listener middleware API name and signature by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2005
- feat(alm): add cancellation message to TaskAbortError, listenerApi.signal & forkApi.signal. by @FaberVitale in https://github.com/reduxjs/redux-toolkit/pull/2023
- [fix][1.8.0-integration][alm]: missing type export by @FaberVitale in https://github.com/reduxjs/redux-toolkit/pull/2026
- [chore][1.8.0-integration][alm]: apply alm breaking API changes to counter-example by @FaberVitale in https://github.com/reduxjs/redux-toolkit/pull/2025
- Reorganize serializable check conditions by @msutkowski in https://github.com/reduxjs/redux-toolkit/pull/2000
- fix(alm): prevent zombie listeners caused by forked tasks by @FaberVitale in https://github.com/reduxjs/redux-toolkit/pull/2070
- Integrate the listener middleware into the RTK package by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2072
- fix(alm): cancel forkApi.delay and forkApi.pause if listener is cancelled or completed by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2074
- chore(alm): update counter example to 1.8.0 by @FaberVitale in https://github.com/reduxjs/redux-toolkit/pull/2076
- Enable cancelling active listeners when unsubscribing by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2078
- v1.8.0 integration by @markerikson in https://github.com/reduxjs/redux-toolkit/pull/2024
Full Changelog: https://github.com/reduxjs/redux-toolkit/compare/v1.7.2...v1.8.0
Configuration
📅 Schedule: Branch creation - "every weekend" in timezone Europe/Moscow, 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.
- [ ] If you want to rebase/retry this PR, click this checkbox.
This PR has been generated by Mend Renovate. View repository job log here.
This pull request is being automatically deployed with Vercel (learn more).
To see the status of your deployments, click below or on the icon next to each commit.
redux-eggs-example-next – ./examples/example-next
🔍 Inspect: https://vercel.com/fostyfost/redux-eggs-example-next/846SW4LFFez3ANMWJxZmvkTUCnut
✅ Preview: https://redux-eggs-example-next-git-renovate-reduxjs-t-8144c6-fostyfost.vercel.app
redux-eggs-example-next-gip – ./examples/example-next-gip
🔍 Inspect: https://vercel.com/fostyfost/redux-eggs-example-next-gip/DfYQrr9dqJRgrR4HY5QFyB11wDjk
✅ Preview: https://redux-eggs-example-next-gip-git-renovate-redux-c418e9-fostyfost.vercel.app
redux-eggs-example-next-rtk – ./examples/example-next-rtk
🔍 Inspect: https://vercel.com/fostyfost/redux-eggs-example-next-rtk/FNXFxwtBWWj8bfsCZHxPx2E4Srfv
✅ Preview: https://redux-eggs-example-next-rtk-git-renovate-redux-8c9353-fostyfost.vercel.app
The latest updates on your projects. Learn more about Vercel for Git ↗︎
Name | Status | Preview | Comments | Updated (UTC) |
---|---|---|---|---|
redux-eggs-example-next | ❌ Failed (Inspect) | May 7, 2023 7:59pm | ||
redux-eggs-example-next-gip | ❌ Failed (Inspect) | May 7, 2023 7:59pm | ||
redux-eggs-example-next-rtk | ❌ Failed (Inspect) | May 7, 2023 7:59pm |
Deployment failed with the following error:
Resource is limited - try again in 21 hours (more than 100, code: "api-deployments-free-per-day").
Deployment failed with the following error:
Resource is limited - try again in 20 hours (more than 100, code: "api-deployments-free-per-day").
Deployment failed with the following error:
Resource is limited - try again in 1 hour (more than 100, code: "api-deployments-free-per-day").
Deployment failed with the following error:
Resource is limited - try again in 12 hours (more than 100, code: "api-deployments-free-per-day").
Renovate Ignore Notification
Because you closed this PR without merging, Renovate will ignore this update (1.9.5). You will get a PR once a newer version is released. To ignore this dependency forever, add it to the ignoreDeps
array of your Renovate config.
If you accidentally closed this PR, or if you changed your mind: rename this PR to get a fresh replacement PR.