Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: 검색창 컴포넌트 개선 및 드롭다운 UI 추가 #551

Merged

Conversation

not-using
Copy link
Collaborator

@not-using not-using commented Aug 20, 2023

개요

검색창을 Compound 패턴으로 개선합니다
https://www.patterns.dev/posts/compound-pattern

목적

기존 SearchBar의 복잡성 개선

  • SearchBar 컴포넌트는 여러 상황을 대비해서 다양한 props를 요구하고 props에 맞게 UI를 구성해왔습니다.
  • 또다른 UI 추가 및 변경을 하려면 내부 로직을 변형하여 사용해야 합니다 이 경우 기존 UI에 영향을 주지는 않는지 계속 확인해야 합니다
  • compound pattern을 적용해서 확장에 유연하도록 개선합니다

메인페이지와 검색페이지에서만 쓰이는 BookSearchBar 분리

  • 최근검색어, 검색 결과 미리보기 같은 도서 검색에서만 쓰이는 기능을 가진 컴포넌트가 필요합니다
  • 어드민의 검색창은 영향을 받지 않도록 분리합니다

변경사항

SearchBar => BookSearchBar, ManagementSearchBar 변경

  • BookSearchBar와 ManagementBar는 용도에 따라 SearchBar에 필요한 기능을 넣은 컴포넌트
  • SearchBar는 Input, button, dropwon 등 하위 구성요소를 가짐, 하위 구성요소의 다양한 조합으로 활용가능

검색창 드롭다운 추가

  • BookSearchBar는 Focus되었을때 드롭다운이 보이고 검색어의 유무에 따라 최근검색어/검색결과미리보기를 보임
  • 반응형 변화에 맞춰 적절한 위치에 보입니다

Preview

Aug-20-2023 22-11-14
Aug-20-2023 22-09-48

@not-using not-using added 리팩터링 코드 리팩토링 사용자 사서 UI/UX UI/UX 관련 labels Aug 20, 2023
@not-using not-using self-assigned this Aug 20, 2023
용도에 따라 BookSearchBar, ManagementSearchBar로 활용하도록 변경
Compound 패턴으로 SearchBar 확장성 개선
@not-using not-using force-pushed the 550-검색창-컴포넌트-개선-드롭다운-ui-추가 branch 4 times, most recently from 71df195 to 70809f9 Compare August 20, 2023 12:45
검색창 및 드롭다운 Blur 이벤트 추가
@not-using not-using force-pushed the 550-검색창-컴포넌트-개선-드롭다운-ui-추가 branch from 70809f9 to 1d3f404 Compare August 20, 2023 13:11
Copy link
Member

@Jake1152 Jake1152 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

  • em, rem의 차이
  • export default 어떻게 되는지 설명해주셨습니다
    코드 잘 읽었습니다

Copy link
Member

@scarf005 scarf005 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

@not-using not-using merged commit d5db8cf into develop Sep 2, 2023
@scarf005 scarf005 deleted the 550-검색창-컴포넌트-개선-드롭다운-ui-추가 branch September 2, 2023 10:48
not-using added a commit that referenced this pull request Sep 6, 2023
* fix: 메인페이지 인기 도서 순위 오류 해결 (#521)

* fix: 메인페이지 책 타입 Book이 아나리 BookInfo

* fix: 메인페이지 인기도서 rank 속성 추가

* docs: 📝 README에 이름 추가 (#524)

* fix: 도서 수정 categoryId를 숫자로 변경 (#525)

* refactor: 쓰이지 않는 비표준 css 제거 (#545)

* refactor: 검색 바 아이콘 img로 변경 (#546)

* refactor: 검색 바 아이콘 img로 변경

* fix: `alt=""` 속성 추가

장식(아이콘)이라는 점을 명시적으로 표시

* feat: 메인페이지 스크롤을 내려주세요 애니메이션 추가 (#539)

png 이미지 대신 css로 마우스형태 구현, 동작 추가

* fix: Image 컴포넌트 에러 처리 방식 변경 (#538)

* build: 절대경로 import 추가, `MyRentInfo`에 절대경로 적용 (#542)

* build: vite-tsconfig-paths 추가

* build: 절대경로 import 추가

* refactor: `MyRentInfo`에 절대경로 적용

---------

Co-authored-by: nocontribute <>

* refactor: 대출제한일 계산 로직 통합 (#536)

* fix: 불필요한 타입체크 코드 삭제
* fix: addDay 날짜 오류 해결
* feat: string 형태의 날짜 비교 함수 compareDate 추가
* refactor: 대출제한일 계산 로직 변경 및 통합

* fix: 좋아요 취소시 오류 해결 및 리팩토링 (#527)

* fix: 불필요한 검증 코드 삭제
* refactor: 재사용되지 않는 ShowLike 컴포넌트 통합
* feat: 유저 권한을 확인하는 usePermission 훅 추가
* refactor: 로컬스토리지 대신 usePermission 훅으로 권한 명시
* refactor: Like JSX 가독성 개선
* refactor: 모호한 변수명 변경 initBookInfoId => bookInfoId
* refactor: useGetLike 훅 안팎에 중복된 상태 제거
* refactor: PostLike, DeleteLike 네트워크 성공시에만 뷰가 변경되도록 수정
* refactor: import 절대경로로 변경

* feat: 반응형을 위한 useBreakPoint 훅 추가

* fix: 현재 윈도우 너비에 따라 알맞는 헤더 하나만 표시하도록

* refactor: 기본 헤더에서 LNB 분리

* fix: headerMenu js 파일 ts로 변경 및 절대경로 적용

* refactor: 기본 헤더 불필요한 html 태그 정리 및 css 단순화

* refactor: 모바일 헤더 불필요한 html 태그 정리 및 css 단순화

* refactor: 검색창 컴포넌트 개선 및 드롭다운 UI 추가 (#551)

* refactor: SearchBar 용도에 따라 분리 및 합성 방식으로 변경

용도에 따라 BookSearchBar, ManagementSearchBar로 활용하도록 변경
Compound 패턴으로 SearchBar 확장성 개선

* feat: 검색창 드롭다운 UI 추가

검색창 및 드롭다운 Blur 이벤트 추가

* fix: 검색창 드롭다운 배경 투명도 조절

* fix: 검색 결과 변경시 검색창 blur 처리

* feat: 검색창 드롭다운 ESC 키로 끌 수 있도록

* fix: 검색창 드롭다운 padding 설정 삭제

* feat: 최근 검색어 기능 구현 (#553)

* feat: 최근 검색어 기능 추가

* fix: 최근검색어 X 버튼 css 수정

* feat: carousel UI 컴포넌트 추가 및 메인페이지에 적용 (#560)

* refactor: interval 설정 부분 훅으로 추출

* refactor: useBound 훅에서 event 마다 선택할 수 있도록 props 설정

* feat: useResponsiveWidth 훅 추가

pc, tablet, mobile 환경에 맞는 사이즈 확인용

* refactor: 메인 신규도서 책크기 useResponsiveWidth 훅 적용

* feat: Carousel 컴포넌트 추가

무한 회전하는 슬라이딩 UI, 조합하여 사용할 수 있도록

* refactor: 메인 신규도서 Carousel 형식으로 변경 및 불필요한 태그 depth 제거

* fix: Carousel 사이즈 대신 container 안에 count로 지정할 수 있도록

size나 count 둘 중 하나를 props로 받아서 displayCount를 결정

* fix: Carousel flex 설정으로 너비 보장 안되는 문제 해결

itemSize로 지정한 크기가 조정되지 않도록 flex-grow, flex-shrink 설정 추가

* fix: Carousel 자동 애니메이션 props isAutoAnimated로 제어하도록

- mount 시 useInterval 자동 실행 막음
- props isAutoAnimated True 일때만 carousel 자동으로 돌아가도록
- isAutoAnimated와 isSmoothAnimated 변수 구분

* fix: onPrev 제대로 넘어가지 않던 문제 수정

index가 0이 아닌 1부터 시작하도록 조정

* fix: Carousel 세로형 itemCount = 1일 때 동작오류 수정

translateX와 translateY 설정 및 items이 적을때만 복사 추가

* fix: Carousel 항상 items 뒤에 복사해서 붙이도록 수정

* fix: Carousel list 키 관련 타입오류 수정

* fix: 모바일 화면 메인 신규리스트 동작 오류 수정

* fix: Carousel 가로형 itemCount = 1일 때 UI오류 수정, flexBasis 속성이 필요함

* refactor: 컨테이너와 ContextProvider 분리 및 컴포넌트 파일 독립

- 버튼이나 페이지네이션이 컨테이너 밖에 위치할 수 있도록 Provider와 분리

* fix: 메인 신규도서 컨테이너 컴포넌트 추가

* fix: useApi 임시 활용방법 추가 (#564)

url data도 호출 시점에 전달할 수 있도록

* feat: 검색결과 미리보기 기능 구현 (#555)

* feat: 검색결과 미리보기 UI 구현

* feat: 검색결과 미리보기에서 검색어와 일치할때 색상 강조 추가

* fix: EmphasisInString default props 설정

* fix: EmphasisInString 강조 단어로 시작할때 제대로 적용되지 않는 문제 수정

index = 0 일 때도 적용되도록

* fix: EmphasisInString 대소문자 구분하지 않도록

* fix: EmphasisInString 원래 문자열의 대소문자 형식 변형되던 문제 수정

wholeString 그대로 보일 수 있도록 수정

* fix: autocomplete api 수정 내용 mockdata 반영

* fix: 검색결과 미리보기 키보드 제어 삭제 및 hover 방식으로 변경

* fix: 검색결과 미리보기 레이아웃 변경

* refactor: 검색결과 미리보기 컴포넌트 구조 단순화

* refactor: Pagination 컴파운드 패턴 적용한 Paginations 방식으로 변경

* fix: 검색결과 미리보기 Pagination 방식 변경

* feat: 검색결과 미리보기에 전체 검색결과 카운트 보여주도록

* fix: 페이지네이션 disabled 인 이동버튼 투명도 적용

* fix: autocomplete api 수정사항 반영

* fix: 검색결과 프리뷰 mock 대신 실제 api 연결

* feat: 검색결과 미리보기 로딩 추가

* fix: 검색결과 미리보기 클릭시 상세로 이동되지 않던 오류 수정

* feat: 메인 추천 도서 기능 구현 (#565)

* feat: 추천 도서 기본 UI 구현

* feat: 추천도서 도서 클릭시 해당 도서 상세로 이동

* feat: 메인 추천도서 양 옆 버튼 추가

* fix: 메인 추천도서 모바일 반응형 개선

* feat: 메인 서클별 추천도서 api 연결

* refactor: 메인 신작도서 페이지네이션 추출

* feat: 메인 추천도서에도 원형 페이지네이션 적용

* fix: 메인 서클별 추천도서 반응형 css 수정

* fix: Carousel 길이가 바뀌었을 때 슬라이드 초기화

* feat: 인기검색어 구현 (#566)

* feat: 인기검색어 구현

* chore: 오타 수정

* fix: 검색개선 UI 피드백 반영 (#568)

* fix: 인기검색어 UI 피드백 반영, 검색어 클릭시 검색결과로 이동

* fix: 검색결과 UI 피드백 반영, 긴 검색어는 줄바꿈 하도록

* fix: 메인 신작도서 모바일 화면 튀어나온 버튼 위치 조정

* fix: 메인 추천도서 UI 피드백 반영, 로딩 추가 및 리스트 하나일때 자동 애니메이션 해제

* fix: 인기검색어 모바일일때 fixed 해제

* fix: 검색결과 미리보기 UI 피드백 반영, 검색결과 없을때 ui 개선

* fix: 검색 개선 UI 피드백 2차 (#570)

* fix: 검색결과 미리보기 로딩 중 검색결과없습니다 문구 안보이도록

* fix: 검색결과 더보기 클릭시 미리보기 닫히도록

* fix: 검색창 드롭다운 제대로 focus 안되던 문제 수정

* fix: 검색어 변경시 결과 미리보기 page가 갱신되지 않던 문제 수정

* fix: 검색결과 미리보기 전체 검색결과 더보기를 검색결과 없을때 보이지 않도록

* fix: 공백만 검색했을 때 최근검색어에 추가하지 않도록

* fix: 검색 api요청시 기본 옵션 sort title 설정

* fix: 도서 수정 카테고리 제대로 적용되지 않던 오류 해결

* fix: 추천도서 과격한 애니메이션 수정, 캐러셀 초반에 트랜지션 끌 수 있도록

* fix: 검색결과 미리보기 totalCount 없을때 0 나오던 문제 수정

* fix: 최근 검색어 최대 10개로 제한 (#572)

---------

Co-authored-by: mink97 <[email protected]>
Co-authored-by: scarf <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
Status: Done
Development

Successfully merging this pull request may close these issues.

검색창 컴포넌트 개선, 드롭다운 UI 추가
3 participants