freeCodeCamp/curriculum/challenges/portuguese/03-front-end-development-li.../redux/handle-an-action-in-the-sto...

3.2 KiB

id title challengeType forumTopicId dashedName
5a24c314108439a4d4036150 Manipular uma ação na store 6 301444 handle-an-action-in-the-store

--description--

Depois que uma ação é criada e despachada, a store do Redux precisa saber como responder a essa ação. Esse é o trabalho de uma função reducer. Reducers em Redux são responsáveis pelas modificações de estado que ocorrem em resposta a ações. Um reducer recebe como argumentos state e action, e ele sempre retorna um novo state. É importante ver que esse é o único papel do reducer. Ele não tem efeitos colaterais — nunca chama uma rota de API e nunca tem nenhuma surpresa escondida. O reducer é simplesmente uma função pura que exige os parâmetros state e action, e depois retorna um novo state.

Outro princípio chave em Redux é que o state é somente de leitura. Em outras palavras, a função reducer deve sempre retornar uma nova cópia do state e nunca modificar o estado diretamente. Redux não impõe imutabilidade do estado. No entanto, você é responsável por aplicá-la no código de suas funções reducer. Você vai praticar isso em desafios futuros.

--instructions--

O editor de código tem o exemplo anterior, bem como o início de uma função reducer para você. Preencha o corpo da função reducer para que se receber uma ação do tipo 'LOGIN' ele retorna um objeto state com login definido como true. Caso contrário, retorna o state atual. Note que o state atual e a action despachada foram passados para o reducer, para que você possa acessar o tipo da ação diretamente com action.type.

--hints--

Chamar a função loginAction deve retornar um objeto com a propriedade type definida para a string LOGIN.

assert(loginAction().type === 'LOGIN');

A store deve ser inicializada com um objeto com a propriedade login definida como false.

assert(store.getState().login === false);

Despachar loginAction deve atualizar a propriedade login no state da store para true.

assert(
  (function () {
    const initialState = store.getState();
    store.dispatch(loginAction());
    const afterState = store.getState();
    return initialState.login === false && afterState.login === true;
  })()
);

Se a ação não é do tipo LOGIN, a store deve retornar o estado atual.

assert(
  (function () {
    store.dispatch({ type: '__TEST__ACTION__' });
    let afterTest = store.getState();
    return typeof afterTest === 'object' && afterTest.hasOwnProperty('login');
  })()
);

--seed--

--seed-contents--

const defaultState = {
  login: false
};

const reducer = (state = defaultState, action) => {
  // Change code below this line

  // Change code above this line
};

const store = Redux.createStore(reducer);

const loginAction = () => {
  return {
    type: 'LOGIN'
  }
};

--solutions--

const defaultState = {
  login: false
};

const reducer = (state = defaultState, action) => {

  if (action.type === 'LOGIN') {
    return {login: true}
  }

  else {
    return state
  }

};

const store = Redux.createStore(reducer);

const loginAction = () => {
  return {
    type: 'LOGIN'
  }
};