Files
msgapp/src/app/page.tsx

125 lines
8.0 KiB
TypeScript
Raw Normal View History

import { HeroBanner } from "@/app/components/HeroBanner";
2025-10-24 21:24:51 +09:00
import HorizontalCardScroller from "@/app/components/HorizontalCardScroller";
import CategoryBoardBrowser from "@/app/components/CategoryBoardBrowser";
2025-10-31 00:02:17 +09:00
import ProfileLabelIcon from "@/app/svgs/profilelableicon";
import SearchIcon from "@/app/svgs/SearchIcon";
2025-10-08 20:55:43 +09:00
2025-10-13 18:06:46 +09:00
export default async function Home({ searchParams }: { searchParams: Promise<{ sort?: "recent" | "popular" } | undefined> }) {
const sp = await searchParams;
const sort = sp?.sort ?? "recent";
2025-10-08 20:55:43 +09:00
return (
<div className="space-y-8">
{/* 히어로 섹션: 상단 대형 비주얼 영역 */}
<section>
<HeroBanner />
</section>
2025-10-24 21:24:51 +09:00
{/* 1행: 커스텀 중앙 50vw 주황 스크롤바 */}
{(() => {
const items = [
{ id: 1, region: "경기도", name: "라온마사지샾", address: "수원시 팔달구 매산로 45", image: "/sample.jpg" },
{ id: 2, region: "강원도", name: "휴앤힐링마사지샾", address: "춘천시 중앙로 112", image: "/sample.jpg" },
{ id: 3, region: "충청북도", name: "소담마사지샾", address: "청주시 상당구 상당로 88", image: "/sample.jpg" },
{ id: 4, region: "충청남도", name: "아늑마사지샾", address: "천안시 동남구 시민로 21", image: "/sample.jpg" },
{ id: 5, region: "전라북도", name: "편안한마사지샾", address: "전주시 완산구 풍남문로 77", image: "/sample.jpg" },
{ id: 6, region: "전라남도", name: "바른마사지샾", address: "여수시 중앙로 9", image: "/sample.jpg" },
{ id: 7, region: "경상북도", name: "늘봄마사지샾", address: "대구시 중구 동성로3길 12", image: "/sample.jpg" },
{ id: 8, region: "경상남도", name: "편히쉬다마사지샾", address: "창원시 성산구 중앙대로 150", image: "/sample.jpg" },
{ id: 9, region: "제주특별자치도", name: "제주소풍마사지샾", address: "제주시 중앙로 230", image: "/sample.jpg" },
{ id: 10, region: "서울특별시", name: "도심휴식마사지샾", address: "강남구 테헤란로 427", image: "/sample.jpg" },
];
return <HorizontalCardScroller items={items} />;
})()}
2025-10-30 20:47:34 +09:00
{/* 2행: 고정 높이 610px */}
<section className="min-h-[514px] overflow-hidden">
<div className="grid grid-cols-1 md:grid-cols-2 xl:[grid-template-columns:1fr_2fr_2fr] gap-4 h-full min-h-0">
2025-10-31 00:02:17 +09:00
<div className="hidden xl:grid relative overflow-hidden rounded-xl bg-white px-[25px] py-[34px] grid-rows-[120px_120px_1fr] gap-y-[32px] h-full w-full md:min-w-[350px]">
<div className="absolute inset-x-0 top-0 h-[56px] bg-[#d5d5d5] z-0" />
<div className="h-[120px] flex items-center justify-center relative z-10">
2025-10-30 20:47:34 +09:00
<div className="flex items-center justify-center gap-[8px]">
<img src="https://picsum.photos/seed/profile/200/200" alt="프로필" className="w-[120px] h-[120px] rounded-full object-cover" />
<div className="w-[62px] h-[62px] rounded-full bg-neutral-200 flex items-center justify-center text-[11px] text-neutral-700">
Lv
</div>
</div>
2025-10-24 21:24:51 +09:00
</div>
2025-10-31 00:02:17 +09:00
<div className="h-[120px] flex flex-col items-center relative z-10">
<div className="text-[18px] text-[#5c5c5c] font-[700] truncate text-center mb-[20px]"></div>
<div className="w-[300px] pl-[67px] flex flex-col gap-[12px]">
<div className="grid grid-cols-[64px_auto] gap-x-[24px] items-center h-[16px]">
2025-10-30 20:47:34 +09:00
<div className="w-[64px] flex items-center">
2025-10-31 00:02:17 +09:00
<ProfileLabelIcon width={16} height={16} />
<span className="ml-[8px] text-[12px] text-[#8c8c8c] font-[700]"></span>
2025-10-30 20:47:34 +09:00
</div>
2025-10-31 00:02:17 +09:00
<div className="text-[16px] text-[#5c5c5c] font-[700]">Lv. 79</div>
2025-10-30 20:47:34 +09:00
</div>
2025-10-31 00:02:17 +09:00
<div className="grid grid-cols-[64px_auto] gap-x-[24px] items-center h-[16px]">
2025-10-30 20:47:34 +09:00
<div className="w-[64px] flex items-center">
2025-10-31 00:02:17 +09:00
<ProfileLabelIcon width={16} height={16} />
<span className="ml-[8px] text-[12px] text-[#8c8c8c] font-[700]"></span>
2025-10-30 20:47:34 +09:00
</div>
2025-10-31 00:02:17 +09:00
<div className="text-[16px] text-[#5c5c5c] font-[700]">Iron</div>
2025-10-30 20:47:34 +09:00
</div>
2025-10-31 00:02:17 +09:00
<div className="grid grid-cols-[64px_auto] gap-x-[24px] items-center h-[16px]">
2025-10-30 20:47:34 +09:00
<div className="w-[64px] flex items-center">
2025-10-31 00:02:17 +09:00
<ProfileLabelIcon width={16} height={16} />
<span className="ml-[8px] text-[12px] text-[#8c8c8c] font-[700]"></span>
2025-10-30 20:47:34 +09:00
</div>
2025-10-31 00:02:17 +09:00
<div className="text-[16px] text-[#5c5c5c] font-[700]">1,600,000</div>
2025-10-30 20:47:34 +09:00
</div>
</div>
2025-10-24 21:24:51 +09:00
</div>
2025-10-31 00:02:17 +09:00
<div className="flex flex-col gap-[12px] relative z-10">
<button className="relative w-[300px] h-[32px] rounded-full bg-[#8c8c8c] hover:bg-[#7a7a7a] text-white text-[12px] font-[700] flex items-center">
<span className="absolute left-[100px] inline-flex items-center">
<SearchIcon width={16} height={16} />
<span className="ml-[8px]"> </span>
2025-10-30 20:47:34 +09:00
</span>
</button>
2025-10-31 00:02:17 +09:00
<button className="relative w-[300px] h-[32px] rounded-full bg-[#8c8c8c] hover:bg-[#7a7a7a] text-white text-[12px] font-[700] flex items-center">
<span className="absolute left-[100px] inline-flex items-center">
<SearchIcon width={16} height={16} />
<span className="ml-[8px]"> </span>
2025-10-30 20:47:34 +09:00
</span>
</button>
2025-10-31 00:02:17 +09:00
<button className="relative w-[300px] h-[32px] rounded-full bg-[#8c8c8c] hover:bg-[#7a7a7a] text-white text-[12px] font-[700] flex items-center">
<span className="absolute left-[100px] inline-flex items-center">
<SearchIcon width={16} height={16} />
<span className="ml-[8px]"> </span>
2025-10-30 20:47:34 +09:00
</span>
2025-10-31 00:02:17 +09:00
<span className="absolute right-[8px] w-[47px] h-[18px] rounded-full bg-white text-[#707070] text-[10px] font-[600] leading-[18px] flex items-center justify-end pr-[6px]">12 </span>
2025-10-30 20:47:34 +09:00
</button>
2025-10-31 00:02:17 +09:00
<button className="relative w-[300px] h-[32px] rounded-full bg-[#8c8c8c] hover:bg-[#7a7a7a] text-white text-[12px] font-[700] flex items-center">
<span className="absolute left-[100px] inline-flex items-center">
<SearchIcon width={16} height={16} />
<span className="ml-[8px]"> </span>
2025-10-30 20:47:34 +09:00
</span>
2025-10-31 00:02:17 +09:00
<span className="absolute right-[8px] w-[47px] h-[18px] rounded-full bg-white text-[#707070] text-[10px] font-[600] leading-[18px] flex items-center justify-end pr-[6px]">7 </span>
2025-10-30 20:47:34 +09:00
</button>
2025-10-24 21:24:51 +09:00
</div>
</div>
<div className="rounded-xl overflow-hidden h-full min-h-0 flex flex-col">
<CategoryBoardBrowser />
</div>
2025-10-30 20:47:34 +09:00
<div className="flex flex-col rounded-xl overflow-hidden h-full min-h-0">
2025-10-24 21:24:51 +09:00
<CategoryBoardBrowser categoryName="명예의 전당" categorySlug="hall-of-fame" />
</div>
</div>
</section>
2025-10-24 21:24:51 +09:00
{/* 3행: 최소/최대 높이 + 내부 스크롤 가능 */}
<section className="min-h-[514px] md:h-[620px] overflow-hidden">
<div className="grid grid-cols-1 md:grid-cols-2 gap-4 h-full min-h-0">
<div className="rounded-xl overflow-hidden h-full min-h-0 flex flex-col">
<CategoryBoardBrowser categoryName="소통방" categorySlug="community" />
</div>
<div className="rounded-xl overflow-hidden h-full min-h-0 flex flex-col">
<CategoryBoardBrowser categoryName="제휴업소 정보" categorySlug="partner-info" />
</div>
</div>
</section>
2025-10-08 20:55:43 +09:00
</div>
);
}