'Redux toolkit: Uncaught TypeError: Cannot read properties of undefined (reading 'type')

I get the following error when I add a specific action in the extraReducers inside a slice:

Uncaught TypeError: Cannot read properties of undefined (reading 'type').

Example:

import { createSlice } from '@reduxjs/toolkit'

export const mySlice = createSlice({
  name: 'name',
  initialState,
  extraReducers: (builder) => {
    // If I console.log action2 here, it turns out to be undefined
    builder.addCase(action1, () => ...) 
    builder.addCase(action2, () => ...) // when I add this specific action I get the error.
  },
  reducers: {
    ...
  },
})

action2 is defined like action1, in another file:

import { createAction } from '@reduxjs/toolkit'

export const action2 = createAction(
  'action2'
)

Why action2 is undefined in mySlice? Did I miss something?

Update: from the documentation:

Action creators that were generated using createAction may be used directly as the keys here, using computed property syntax.

If I got the sentence properly, I can replace this part:

builder.addCase(action2, () => ...)

with this:

builder.addCase("action2", () => ...)

That indeed would resolve the problem. Would this solution be correct?

Even so, it could be nice to understand why action2 appears to be undefined when used with the first approach.



Solution 1:[1]

You are most likely running into a circular import dependency issue. Are any other slice files importing this one as well? If so, that will usually cause one of the slices to not be initialized at the time that the other file's createSlice call runs, and thus all the action creators being imported are still undefined.

https://redux-toolkit.js.org/usage/usage-guide#exporting-and-using-slices

RTK version 1.7.0-beta.1 actually has a potential fix for this issue, by lazily-instantiating the reducer. Please try that out and see if it fixes things for you:

https://github.com/reduxjs/redux-toolkit/releases/tag/v1.7.0-beta.1

Solution 2:[2]

I didn't understand your question, but i solved the relevant error, please check the code

this is my creating slice code

const counterSlice = createSlice({
  name: "Counter",
  initialState: initialState,
  reducers: {
    incer: studentData,
    decrement: Decrement,
  },
  extraReducers(builder) {
    builder
      .addCase(fetchPost.pending, postsRequested)
      .addCase(fetchPost.fulfilled, postsRecived)
      .addCase(fetchPost.rejected, postReuestFailed);
  },
});

this is my reducer code

export const postsRequested = (state, action) => {
  state.status = "loading";
};

export const postsRecived = (state, action) => {
  state.status = "Sucess";
  const loadedPost = action.payload;
  state.students.push(loadedPost);
};

export const postReuestFailed = (state, action) => {
  state.status = "Failed";
  state.error = action.error.message;
};

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 markerikson
Solution 2 Anuj