Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Angular 6 ngrx, how to add new item to array in state object?

I have a simple situation, I have actions Like CreatUser, CreateSuccess, CreateFail. How should I add new object to array and when Create action is dispatched or CreateSuccess? And how should I do that?

export function reducer(state = init, action: Actions): State {
switch (action.type) {
    case ActionsTypes.CREATE:
        return {
            ...state,
            inProgress: true
        };
    case ActionsTypes.CREATE_SUCCESS:
        return {
            ...state,
            users: state.users.push(action.payload),
            inProgress: false
        };
    case ActionsTypes.CREATE_FAIL:
        return {
            ...state,
            error: action.payload,
            inProgress: false
        };
    default:
        return state;
}

In code above I tried to add new user using push method, but it is not good solution. How should I do that?

like image 693
Adam Adamski Avatar asked Aug 31 '18 06:08

Adam Adamski


4 Answers

Try to use the spread operator because it creates a new array of users and does not mutate the previous array.

users: [...state.users, action.payload]

Or else use @ngrx/entity module for arrays. It's the best way.

Update 13.07.2019

New module @ngrx/data is available in NgRx 8. This module helps to create CRUD store for arrays with zero boilerplate.

like image 175
Kliment Ru Avatar answered Nov 04 '22 07:11

Kliment Ru


Your state should be immutable therefore would be better to use

users: state.users.concat(action.payload)
like image 29
Igor Litvinovich Avatar answered Nov 04 '22 05:11

Igor Litvinovich


This is for those who is searching how to add item at the begining of the array in an immutable manner unlike using unshift operator which mutates the original. Placing new item at the begining of operation makes the magic

users: [action.payload,...state.users]

like image 6
sai amar Avatar answered Nov 04 '22 07:11

sai amar


export const reducer = createReducer(initialState,
  on(addTodo, (state, { todo }) => ({
    ...state,
    todoInput: '',
    todos: [...state.todos, todo]
  }))
);

See: https://ngrx.io/guide/store/configuration/runtime-checks

like image 6
Manuel Gonzalez Avatar answered Nov 04 '22 06:11

Manuel Gonzalez