inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[리뉴얼] React로 NodeBird SNS 만들기

immer 도입하기

Immer 적용시 에러 문의드립니다.

553

나는배나옴

작성한 질문수 1

0

안녕하세요. React Immer 적용시 나타나는 에러인데

확인한번 부탁드려도 될까요?

Immer 적용 전까지 코드는 잘 돌아갔는데, 에러 추적이 힘드네요. 웹 팩 환경설정 문제일까요?

 immer module은 잘 설치되어 있습니다.

 

에러내용

소스코드

front/reducers/user.js

import produce from 'immer';

export const initialState = {
  logInLoading : false, // 로그인 시도중
  logInDone : false,
  loginError : null,

  logOutLoading : false, // 로그아웃 시도중
  logOutDone : false,
  logOutError : null,

  signUpLoading : false, // 회원가입 시도중
  signUpDone : false,
  signUpFailure : null,

  changeNicknameLoading : false, // 닉네임 변경 시도중
  changeNicknameDone : false,
  changeNicknameFailure : null,  

  me : null,
  signUpData : {},
  loginData : {},
};

const dummyUser = (data) => ({
  ...data,
  nickname : '제로초',
  id : 1,
  Posts : [{ id : 1}],
  Followings : [{nickname : 'AAA'}, {nickname : 'BBB'}, {nickname : 'CCC'}],
  Followers : [{nickname : 'AAA'}, {nickname : 'BBB'}, {nickname : 'CCC'}],
});

export const LOG_IN_REQUEST  = 'LOG_IN_REQUEST'; // 액션의 이름
export const LOG_IN_SUCCESS  = 'LOG_IN_SUCCESS'; 
export const LOG_IN_FAILURE  = 'LOG_IN_FAILURE'; 

export const LOG_OUT_REQUEST = 'LOG_OUT_REQUEST'; // 액션의 이름
export const LOG_OUT_SUCCESS = 'LOG_OUT_SUCCESS'; 
export const LOG_OUT_FAILURE = 'LOG_OUT_FAILURE';

export const SIGN_UP_REQUEST = 'SIGN_UP_REQUEST';
export const SIGN_UP_SUCCESS = 'SIGN_UP_SUCCESS';
export const SIGN_UP_FAILURE = 'SIGN_UP_FAILURE';

export const CHANGE_NICKNAME_REQUEST = 'CHANGE_NICKNAME_REQUEST';
export const CHANGE_NICKNAME_SUCCESS = 'CHANGE_NICKNAME_SUCCESS';
export const CHANGE_NICKNAME_FAILURE = 'CHANGE_NICKNAME_FAILURE';

export const FOLLOW_REQUEST = 'FOLLOW_REQUEST';
export const FOLLOW_SUCCESS = 'FOLLOW_SUCCESS';
export const FOLLOW_FAILURE = 'FOLLOW_FAILURE';

export const UNFOLLOW_REQUEST = 'UNFOLLOW_REQUEST';
export const UNFOLLOW_SUCCESS = 'UNFOLLOW_SUCCESS';
export const UNFOLLOW_FAILURE = 'UNFOLLOW_FAILURE';

export const ADD_POST_TO_ME = 'ADD_POST_TO_ME';
export const REMOVE_POST_OF_ME = 'REMOVE_POST_OF_ME';

export const signUpAction = (data) => {
  return {
    type: SIGN_UP_REQUEST,
    data,
  };
};

export const changeNicknameAction = (data) => {
  return {
    type: CHANGE_NICKNAME_REQUEST,
    data,
  };
};

export const loginRequestAction = (data) => {
  return {
    type: LOG_IN_REQUEST,
    data,
  }
};

export const logoutRequestAction = {
  type: LOG_OUT_REQUEST,
};


const reducer = (state = initialState, action) => produce(state, (draft) => {
    switch (action.type) {
      // 로그인
      case LOG_IN_REQUEST: 
        draft.state = true;
        draft.loginError = null;
        draft.logInDone = false;
        break;
      case LOG_IN_SUCCESS: 
        draft.logInLoading = false;
        draft.logInDone = true;
        draft.me = dummyUser(action.data);
        break;
      case LOG_IN_FAILURE: 
        draft.logInLoading =  false;
        draft.loginError = action.error;
        break;

      // 로그아웃
      case LOG_OUT_REQUEST :       
        draft.logOutLoading =  true;
        draft.logOutError =  null;
        break;
      case LOG_OUT_SUCCESS : 
        draft.logOutLoading = false;
        draft.logOutDone = false;
        draft.me =  null;
        break;
      case LOG_OUT_FAILURE : 
        draft.logOutLoading =   false;
        draft.logOutError = action.error;
        break; 

      // 회원가입
      case SIGN_UP_REQUEST : 
          draft.signUpLoading = true;
          draft.signUpDone = false;
          draft.signUpError = null;
          break;
      case SIGN_UP_SUCCESS : 
          draft.signUpLoading =  false;
          draft.signUpDone =  true;
          break;
      case SIGN_UP_FAILURE : 
          draft.signUpLoading = false;
          draft.signUpData = action.error;     
          break;         
        
      // 닉네임 변경
      case CHANGE_NICKNAME_REQUEST : 
          draft.changeNicknameLoading= true;
          draft.changeNicknameDone= false;
          draft.changeNicknameError= null;
          break;
      case CHANGE_NICKNAME_SUCCESS : 
          draft.changeNicknameLoading = false;
          draft.changeNicknameDone =  true;
          break;
      case CHANGE_NICKNAME_FAILURE : 
          draft.changeNicknameLoading = false;
          draft.changeNicknameData =  action.error;
          break;
    
      // 게시글 등록시 사용자 dummy Data에 동기화
      case ADD_POST_TO_ME : 
        draft.me.Posts.unshift({ id : action.data})
        break;
        // return {
        //   ...state,
        //   me : {
        //     ...state.me
        //     Posts: [ { id.action.data}, ...state.me.Posts]
        //   }
        // }

      // 게시글 삭제
      case REMOVE_POST_OF_ME : 
        draft.me.Posts = draft.me.Posts.filter((v) => v.id !== action.data)
        break;
        // return  {
        //     ...state, 
        //     me : {
        //       ...state.me,
        //       Posts : state.me.Posts.filter((v) => v.id !== action.data)
        //     }
        // }

      default:  
        break;
      }
  });
  
  export default reducer;

 

react redux node.js express next.js

답변 1

1

제로초(조현영)

import { produce } from 'immer'

1

나는배나옴

감사합니다. 항상 귀중한 강의 잘보고있습니다.리액트 사용해서 저도 멋진 프로젝트 하나 만들어보고싶네요.

익숙해질때까지 계속 반복해서 보겠습니다.

넥스트 버젼 질문

0

78

2

로그인시 401 Unauthorized 오류가 뜹니다

0

90

1

무한 스크롤 중 스크롤 튐 현상

0

176

1

특정 페이지 접근을 막고 싶을 때

0

103

2

createGlobalStyle의 위치와 영향범위

0

97

2

인라인 스타일 리렌더링 관련

0

92

2

vsc 에서 npm init 설치시 오류

0

148

2

nextjs 15버전 사용 가능할까요?

0

160

1

화면 새로고침 문의

0

122

1

RTK에서 draft, state 차이가 있나요?

0

154

2

Next 14 사용해도 될까요?

0

452

1

next, node 버전 / 폴더 구조 질문 드립니다.

0

349

1

url 오류 질문있습니다

0

211

1

ssh xxxxx로 우분투에 들어가려니까 port 22: Connection timed out

0

375

1

sudo certbot --nginx 에러

0

1280

2

Minified React error 콘솔에러 (hydrate)

0

470

1

카카오 공유했을 때 이전에 작성했던 글이 나오는 버그

0

247

1

프론트서버 배포 후 EADDRINUSE에러 발생

0

329

1

npm run build 에러

0

519

1

front 서버 npm run build 중에 발생한 에러들

0

382

1

서버 실행하고 브라우저로 들어갔을때 404에러

0

338

2

css 서버사이드 랜더링이 적용되지 않아서 문의 드립니다.

0

289

1

팔로워 3명씩 불러오고 데이터 합쳐주는걸로 바꾸고 서버요청을 무한으로하고있습니다.

0

240

2

해시태그 검색에서 throttle에 관해 질문있습니다.

0

202

1