티스토리 뷰
Dev/Racstagram_V2
20210710 리팩토링 Instagram 클론 프로젝트 by Redux-toolkit03 : Auth 재편성, 회원가입 구현, Auth 관련 사항 마무리
라쿤 2021. 7. 11. 03:09리팩토링 Instagram 클론 프로젝트 by Redux-toolkit03

📄 프로젝트 설명
이 프로젝트는 기존에 React & firebase를 통해서 만든 인스타그램 클론 프로젝트 리팩토링 프로젝트 입니다. (해당 프로젝트는 프로젝트 카테고리에서 확인 가능합니다.)
해당 프로젝트에서는 redux-toolkit(Slice 모델)을 사용하여 상태관리를 구현하고 있습니다.
더불어 나중에, styled component나 sass 중에 채택하여 css 작업을 할 예정 입니다.
💻 화면 개요
체크는 현재 구현된 상황을 의미합니다.
-
로딩 화면 또는 Component: 앱 실행 초기화 작업시 로딩 또는 다른 작업시 사용할 로딩 화면 및 Component -
로그인 화면: 기본 Email 로그인, Social 로그인, 로그인 에러-
Email 로그인: Email, Password input, 로그인 버튼 -
Social 로그인: google로그인 버튼, github로그인 버튼 -
로그인 에러: Email로그인, google로그인, github 로그인 에러 발생시 사용자에게 출력
-
-
회원가입 화면: Email 로그인을 위한 계정을 만드는 화면, 회원가입 에러-
Email 형식 가입: Email, Password input, 회원가입 버튼- 가입시 사용자 Nickname 지정 input (추가 사항)
-
-
피드 화면: 사용 유저의 모든 게시글을 표시하는 화면-
게시글 박스:-
타이틀 영역: 최상단의 작성자 사진 + 이름, 게시글 수정 탭 -
사진 영역: 기존에는 1개만 가능했음 (욕심내면, 여러개 슬라이드 형식으로 가능하게 하고 싶음) -
내용 영역: 게시글 내용
-
-
-
현재 유저 프로필 화면: 로그인한 현재 유저의 게시물과 대략적인 프로필를 표시하는 화면 -
유저 프로필 화면: 유저의 게시물과 프로필을 확인 할수 있는 화면 (피드 게시글 작성자 유저 이름을 눌러 유저 프로필 화면으로 이동) -
네비게이션 바: 앱로고 - 피드(Home)탭 - 글 작성탭 - 현재 유저 프로필(프로필 수정, 프로필 이동, 로그아웃) 탭-
로그아웃
-
📅 TIL (Today I Learned, 오늘 깨달은 것들)
2021.07.10 사항
작업 개요
-
Form 통합: email 로그인 Form , 회원 가입 -> Auth (toggle로 로그인/회원가입 구분)- id, password 넣은 input은 공유하고, 가입화면에만 nickname input 추가 구현
-
email 가입 구현: 가입 input, 가입 요청 작업 구현-
가입 nickname Update: 가입시 nickname input으로 사용할 이름을 받아 사용자 profile displayName을 초기에 설정 (사용자 info는 로그인 해야 업데이트 할 수 있어 바로 로그인 구현) -
바로 로그인 구현
-
-
Error: 가입 Error, 로그인 Error (email, social) 통합으로 하나의 영역에 보이게 구현 -
social 로그인 Redirect 구현: 기존 Popup -> Redirect (브라우저는 popup 띄우는것을 안좋아함, popup시 error로 중지는 안되지만 콘솔에 경고가 뜸)
고민, 생각 및 깨달음
- thunkAPI의 getState는 안에 콜백으로 세세하게 state를 가져오지 못함
- 무조건 전체 state라서 일단 받고, 분리해서 가져와야 함
- 화면에 띄울 에러 메세지는 따로 Error state를 만들어서 어떤 작업중 에러 발생시 error를 update하게 해서 상황에 맞는 Error를 가져와 처리 할수 있음
'Dev > Racstagram_V2' 카테고리의 다른 글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- nrc
- JavaScript
- Python
- Django
- TypeScirpt
- github
- 드림코딩
- redux-toolkit
- 그림판 만들기
- 오버라이딩
- RUBY
- 트위터 클론
- object
- todolist
- 생활코딩
- nodejs
- 기능추가
- instagram CSS
- Class
- project
- 바닐라js
- hooks
- NomadCoder
- React
- html
- async
- css
- Git
- Firebase
| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | ||||||
| 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 | 20 | 21 | 22 |
| 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 30 |
글 보관함
