Skip to content

Commit

Permalink
[feat] 헤더바 구현
Browse files Browse the repository at this point in the history
  • Loading branch information
darkdulgi committed Jul 30, 2024
1 parent 98becfe commit 5e56187
Show file tree
Hide file tree
Showing 3 changed files with 79 additions and 20 deletions.
1 change: 1 addition & 0 deletions src/App.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ function App() {
<>
<IntroSection />
<Header />
<img src="https://image.utoimage.com/preview/cp872655/2018/03/201803016775_500.jpg" className="h-[2000px]"/>
</>
);
}
Expand Down
94 changes: 74 additions & 20 deletions src/header/index.jsx
Original file line number Diff line number Diff line change
@@ -1,31 +1,85 @@
export default function Header(){
import { useEffect, useRef, useState } from "react";
import style from "./index.module.css";

export default function Header() {
const [scrollState, setScrollState] = useState(null);
const scrollListRef = useRef([]);
const [positionList, setPositionList] = useState([]);
const scrollSectionList = [
"추첨 이벤트",
"차량 상세정보",
"기대평",
"선착순 이벤트",
];

useEffect(() => {
const newPositionList = scrollListRef.current.map((ref) => {
const pos = ref.getBoundingClientRect();
return pos.left + ref.offsetWidth / 2 - 25;
});
setPositionList(newPositionList);
}, [scrollState]);

function gotoTop() {
window.scrollTo({ top: 0, behavior: "smooth" });
}

function onClickScrollSection(index) {
/*
* 클릭시 하단의 다양한 영역으로 스크롤되는 코드 미작성
*/

if (index !== scrollState) {
setScrollState(index);
}
}

function openVerifyModal() {
/*
* 본인인증 모달 여는 코드 미작성
*/
}

function scrollDynamicStyle() {
if (scrollState === null) return;
const position = Math.floor(positionList[scrollState]);
return {
"--pos": position,
};
}

return (
<div className="h-[60px] backdrop-blur-xl flex justify-between items-center pl-[36px] pr-[46px] font-bold">
<span className="text-black text-[22px]">
<div className="sticky top-0 h-[60px] backdrop-blur-xl flex justify-between items-center pl-[36px] pr-[46px] font-bold select-none">
<span onClick={gotoTop} className="text-black text-[22px] cursor-pointer">
The new IONIQ 5
</span>

<div className="flex gap-8 text-[16px] text-neutral-300">
<span>
추첨 이벤트
</span>

<span>
차량상세정보
</span>

<span>
기대평
</span>
<div className="flex h-full gap-8 text-[16px]">
{scrollSectionList.map((scrollSection, index) => (
<div
key={index}
ref={(section) => {
scrollListRef.current[index] = section;
}}
onClick={() => onClickScrollSection(index)}
className={`flex items-center cursor-pointer ${scrollState === index ? "text-black" : "text-neutral-300"}`}
>
{scrollSection}
</div>
))}

<span>
선착순 이벤트
</span>
<div
style={scrollDynamicStyle()}
className={`w-[50px] h-[3px] bg-black transition ease-in-out duration-200 absolute bottom-0 left-0 ${scrollState === null ? "hidden" : style.moveBar}`}
/>
</div>

<button className="bg-blue-400 text-white text-[14px] py-[12px] px-[16px]">
<button
onClick={openVerifyModal}
className="bg-blue-400 text-white text-[14px] py-[12px] px-[16px]"
>
본인인증하기
</button>
</div>
);
}
}
4 changes: 4 additions & 0 deletions src/header/index.module.css
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
.moveBar {
transition: all 0.2s ease-in-out;
transform: translateX(calc(var(--pos) * 1px));
}

0 comments on commit 5e56187

Please sign in to comment.