|
1 | 1 | import React from "react"; |
2 | | -// import { useRouter } from "next/navigation"; |
3 | | -import PrizeItem from "@/entities/home/ui/PrizeItem"; |
| 2 | +import { useRouter } from "next/navigation"; |
| 3 | +// import PrizeItem from "@/entities/home/ui/PrizeItem"; |
4 | 4 | import SloganMarquee from "@/entities/home/ui/SloganMarquee"; |
5 | | -// import Button from "@/shared/ui/Button"; |
| 5 | +import Button from "@/shared/ui/Button"; |
6 | 6 | import { cn } from "@/shared/utils/cn"; |
7 | 7 | import { SectionTitle } from "@/shared/ui/SectionTitle"; |
8 | | -// import { formatDate } from "@/shared/utils/formatDate"; |
| 8 | +import { formatDate } from "@/shared/utils/formatDate"; |
9 | 9 |
|
10 | | -const PRIZES = [ |
11 | | - { |
12 | | - rank: "2등", |
13 | | - bg: "bg-gray-400", |
14 | | - emoji: "광주SW마이스터고 2학년 ", |
15 | | - desc: "허O서", |
16 | | - slogan: '"광주의 빛나는, 또 빛날 별들의 향연"', |
17 | | - }, |
18 | | - { |
19 | | - rank: "1등", |
20 | | - bg: "bg-yellow-300", |
21 | | - emoji: "전대사대부고 2학년 ", |
22 | | - desc: "김O은", |
23 | | - slogan: '"세상의 무대 위, 광탈페! 너의 꿈이 시작되는 순간!"', |
24 | | - }, |
25 | | - { |
26 | | - rank: "3등", |
27 | | - bg: "bg-orange-700", |
28 | | - emoji: "빛고을고 2학년 ", |
29 | | - desc: "최O원", |
30 | | - slogan: '"재능이 피어나는 시간, 가능성이 자라는 무대"', |
31 | | - }, |
32 | | -]; |
| 10 | +const SLOGAN_YEAR = 2026; |
33 | 11 |
|
34 | | -// const SLOGAN_START = new Date("2025-05-26T00:00:00+09:00"); |
35 | | -// const SLOGAN_END = new Date("2025-05-30T17:59:59+09:00"); |
| 12 | +const SLOGAN_START = new Date(`${SLOGAN_YEAR}-05-04T00:00:00+09:00`); |
| 13 | +const SLOGAN_END = new Date(`${SLOGAN_YEAR}-05-08T17:59:59+09:00`); |
36 | 14 |
|
37 | 15 | const SloganSecondSection = () => { |
38 | | - // const R = useRouter(); |
| 16 | + const router = useRouter(); |
39 | 17 |
|
40 | | - // const isSloganPeriod = React.useMemo(() => { |
41 | | - // const now = new Date(); |
42 | | - // return now >= SLOGAN_START && now <= SLOGAN_END; |
43 | | - // }, []); |
| 18 | + const [isSloganPeriod, setIsSloganPeriod] = React.useState(false); |
44 | 19 |
|
45 | | - // const submissionPeriodText = React.useMemo(() => { |
46 | | - // const startText = formatDate(SLOGAN_START); |
47 | | - // const endText = formatDate(SLOGAN_END); |
48 | | - // return `공모기간 : 2025.${startText}~${endText} 18:00까지`; |
49 | | - // }, []); |
| 20 | + React.useEffect(() => { |
| 21 | + const checkPeriod = () => { |
| 22 | + const now = new Date(); |
| 23 | + setIsSloganPeriod(now >= SLOGAN_START && now <= SLOGAN_END); |
| 24 | + }; |
| 25 | + |
| 26 | + checkPeriod(); |
| 27 | + const timer = setInterval(checkPeriod, 60000); |
| 28 | + |
| 29 | + return () => clearInterval(timer); |
| 30 | + }, []); |
| 31 | + |
| 32 | + const submissionPeriodText = React.useMemo(() => { |
| 33 | + const startText = formatDate(SLOGAN_START); |
| 34 | + const endText = formatDate(SLOGAN_END); |
| 35 | + return `공모기간 : ${SLOGAN_YEAR}.${startText}~${endText} 18:00까지`; |
| 36 | + }, []); |
50 | 37 |
|
51 | 38 | return ( |
52 | 39 | <section id="SloganSecondSection" className={cn("w-full mt-[3.5rem] mobile:mt-20 text-center")}> |
53 | 40 | <SectionTitle |
54 | | - title="2025 광탈페 슬로건" |
| 41 | + title={`${SLOGAN_YEAR} 광탈페 슬로건`} |
55 | 42 | description={ |
56 | 43 | <> |
57 | 44 | <span className="text-black text-body2b"> |
58 | 45 | 세상의 무대 위, 광탈페! 너의 꿈이 시작되는 순간! |
59 | 46 | </span> |
60 | 47 | <span className={cn("block")}> |
61 | | - 2025년 모두가 주인공이 되는 광주학생탈렌트페스티벌의 꿈의 무대가 펼쳐집니다. |
| 48 | + {SLOGAN_YEAR}년 모두가 주인공이 되는 광주학생탈렌트페스티벌의 꿈의 무대가 펼쳐집니다. |
62 | 49 | </span> |
63 | 50 | </> |
64 | 51 | } |
65 | 52 | /> |
66 | 53 |
|
67 | 54 | <SloganMarquee /> |
68 | 55 |
|
69 | | - <div className={cn("flex flex-col items-center p-6 bg-white my-30")}> |
| 56 | + {/* <div className={cn("flex flex-col items-center p-6 bg-white my-30")}> |
70 | 57 | <div className={cn("flex justify-center items-center gap-[40px]")}> |
71 | 58 | <PrizeItem key={PRIZES[1].rank} {...PRIZES[1]} /> |
72 | 59 | <PrizeItem key={PRIZES[0].rank} {...PRIZES[0]} /> |
73 | 60 | <PrizeItem key={PRIZES[2].rank} {...PRIZES[2]} /> |
74 | 61 | </div> |
75 | | - </div> |
76 | | - {/* |
77 | | - <Button |
78 | | - onClick={() => R.push("/slogan")} |
79 | | - className={cn("my-[24px] mobile:mb-[12px] px-28")} |
80 | | - isDisabled={!isSloganPeriod} |
81 | | - > |
82 | | - <span className={cn("text-body2b mobile:text-body3b flex items-center gap-10")}> |
83 | | - {isSloganPeriod ? "슬로건 공모하러가기" : "공모기간이 아닙니다"} <span>➔</span> |
84 | | - </span> |
85 | | - </Button> |
| 62 | + </div> */} |
| 63 | + <Button |
| 64 | + type="button" |
| 65 | + onClick={() => router.push("/slogan")} |
| 66 | + className={cn("my-[24px] mobile:mb-[12px] px-28")} |
| 67 | + disabled={!isSloganPeriod} |
| 68 | + > |
| 69 | + <span className={cn("text-body2b mobile:text-body3b flex items-center gap-10")}> |
| 70 | + {isSloganPeriod ? "슬로건 공모하러가기" : "공모기간이 아닙니다"} <span>➔</span> |
| 71 | + </span> |
| 72 | + </Button> |
86 | 73 |
|
87 | | - <div className={cn("text-caption1r mobile:text-caption2r text-gray-400")}> |
88 | | - {submissionPeriodText} |
89 | | - </div> */} |
| 74 | + <div className={cn("text-caption1r mobile:text-caption2r text-gray-400")}> |
| 75 | + {submissionPeriodText} |
| 76 | + </div> |
90 | 77 | </section> |
91 | 78 | ); |
92 | 79 | }; |
|
0 commit comments