20210724 리팩토링 Instagram 클론 프로젝트 by Redux-toolkit13 : firebase 보안 규칙 수정, react 이벤트 버블링(stopPropagation 작동 에러), displayName 고유화를 위한 userName 중복 check 구현
리팩토링 Instagram 클론 프로젝트 by Redux-toolkit13
📄 프로젝트 설명
이 프로젝트는 기존에 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개만 가능했음 (욕심내면, 여러개 슬라이드 형식으로 가능하게 하고 싶음)내용 영역
: 게시글 내용
글 작성 화면
: 글을 작성하는 화면
현재 유저 프로필 화면
: 로그인한 현재 유저의 게시물과 대략적인 프로필를 표시하는 화면유저 프로필 수정하기
: 유저 프로필을 수정하는 화면 (userImage, userDisplayname, userIntro)작성 글
: 유저가 작성한 작성 글의 image 표 -> 클릭시 post detail작성 글 detail view
: image 표에서 해당 이미지 클릭시 해당 글 detail view 화면
로그아웃
다른 유저 프로필 화면
: 다른 유저가 작성한 글의 유저 이름을 클릭하여 해당 유저의 프로필 화면 구현프로필 보기
: userImage, userDisplayname, userIntro작성 글
: 유저가 작성한 작성 글의 image 표 -> 클릭시 post detail작성 글 detail view
: image 표에서 해당 이미지 클릭시 해당 글 detail view 화면
네비게이션 바
: 앱로고 - 피드(Home)탭 - 글 작성탭 - 현재 유저 프로필(프로필 수정, 프로필 이동, 로그아웃) 탭- Navigation-profile 눌렀을 때 로그아웃, 프로필 수정, 프로필 이동 드롭 다운 필요
📅 TIL (Today I Learned, 오늘 깨달은 것들)
2021.07.24 사항
작업 개요
firebase firestore 보안 규칙 수정
- users collection의 userDisplayName만 로그인 없이 read 할수 있도록 변경 함
react 이벤트 버블링 현상
- function component 사용시 event.stopPropagation를 사용해도 작동하지 않고 event를 상위에 전달하게 됨 event.preventDefault를 사용해야 전파를 아에 하지 않았음
- class component의 경우에는 event.stopPropagtion이 작동함
- react가 document에 단일 이벤트 리스너 구조인 것은 알지만, 왜 이런 현상이 일어나는지는 모르겠음
displayName 고유화를 위한 checkDisplayName 구현
- 회원가입, profile 수정시 DisplayName 중복 체크 확인 구현
- redux의 users의 checkDisplayName의 exist 프로퍼티인 배열값의 0번은 존재하는 이름인지를 표시, 1번은 검사를 실시한 이름을 뜻함
const users = {
...,
checkDisplayName: {
loading: false,
isCheck: false,
checkError: '',
exist: [false, ''],
}
}
- 프로필 displayName 수정의 경우 자신이 쓰던 displayName에 대한 것도 고려 해야해서 까다로움
- 경우1) 중복확인이 필요하지 않은 경우
- 기존에 쓰던 displayName과 현재 입력창의 input이 같은 경우
(input === prev)
- 기존에 쓰던 displayName과 현재 입력창의 input이 같은 경우
- 경우2) 중복확인이 필요한 경우
- 1.현재 input과 검사한 displayName(결과는 모르지만)과 다를 경우
(input !== chekedName)
- 2.검사한 displayName이 없는 경우(초기값 ‘‘인 경우) ->
(checkedName === '')
- 검사한 displayName이 ‘‘이고 input과 같은 경우도 원하지 않기에 중복 확인이 필요하지만 어차피 chekedName 값 조건에서 필터링이 되기때문에 상관 없음
- 1.현재 input과 검사한 displayName(결과는 모르지만)과 다를 경우
- 경우3) 중복 확인을 한 경우
- 중복O:
- 검사한 이름의 결과 값이 true 인 경우
(checkedValue === true)
- 검사한 이름의 결과 값이 true 인 경우
- 중복X:
- 검사한 이름의 결과 값이 false 인 경우
(checkedValue === false)
- 검사한 이름의 결과 값이 false 인 경우
- 중복O:
- 경우1) 중복확인이 필요하지 않은 경우
경우1과 경우3의 중복X 인 경우
- input과 prev가 같은 경우와, 중복 확인하여 중복이 아닌 경우는 다음을 작업을 진행 해도 됨
// 이름 중복 방어 코드
// input과 과거 이름이 다른 경우
if (prevDisplayName !== input) {
// 검사한 이름이 '' or 검사한 이름이 input과 다른 경우
if (!checkedName || checkedName !== input) {
window.alert("닉네임 중복 확인이 필요 합니다.");
return;
}
// 중복 검사 값이 true 인 경우
if (exist[0]) {
window.alert(`${exist[1]}은 이미 존재하는 닉네임 입니다.`);
return;
}
}
// input과 과거 이름이 같거나, 중복 검사 값이 false인 경우
// update Name
- 로그인의 경우, 자신이 쓰던 displayName이 없어서 그나마 조금 조건이 덜 까다로움
- prev와 input 조건만 없음
다음에 필요한 사항
- Navigation-profile 눌렀을 때 로그아웃, 프로필 수정, 프로필 이동 드롭 다운 필요
- 작성자 이름 고유화 작업 필요
- 선택된 유저의 profile을 가져올 때, 중복 이름이면 잘못 가져오는 에러를 범할 수 있음
- 작성자 이름 설정시 이전에 있는 이름인지 확인하는 작업이 필요 함
- profile 정보 요청 시기 조정
- 더 빠른 연산을 위해서, 화면이 render 되고 profile에 관련된 정보를 가져오지 말고 profile 보기위해 버튼을 눌렀을 때 부터 미리 profile 정보를 요청하게 하자
- profile 요청 작업 보일러 플레이트 코드 줄이기
- 현재 유저와 특정 유저 profile을 요청하는 작업이 비슷하여 보일러 플레이트 코드 발생함
- 조건을 주어 특정 유저 profile 요청 작업으로 통합이 필요함
- 작성글 detail view
- 현재 유저, 특정 유저 postList의 피드 구현 필요
- redux state 식별자 관리(변수명 관리)
- 각 redux에서 사용하는 state의 이름을 통일감 있게 관리 필요