diff --git a/packages/web/src/components/organisms/ChatSection.tsx b/packages/web/src/components/organisms/ChatSection.tsx index 9c82a5c3..27618198 100644 --- a/packages/web/src/components/organisms/ChatSection.tsx +++ b/packages/web/src/components/organisms/ChatSection.tsx @@ -1,13 +1,14 @@ import React, { useEffect } from "react"; import styled from "@emotion/styled"; import { useInView } from "react-intersection-observer"; - -import { Text } from "@biseo/web/components/atoms"; +import { formatDate } from "@biseo/web/utils/format"; +import { Divider, Text } from "@biseo/web/components/atoms"; import { ChatHeader, ChatInput, Message, } from "@biseo/web/components/molecules"; +import { margin, round, padding, center, text } from "@biseo/web/styles"; import { useChat } from "@biseo/web/services"; const Container = styled.div` @@ -36,8 +37,22 @@ export const ChatSection: React.FC = () => { - {messages.map(message => ( - + {messages.map((message, index) => ( + <> + + {formatDate(messages[index + 1]?.createdAt) !== + formatDate(message.createdAt) && ( +
+ + + {formatDate(message.createdAt)} + + +
+ )} + ))} {hasMore && ( diff --git a/packages/web/src/utils/format.ts b/packages/web/src/utils/format.ts index c41d21c2..0fad4e6b 100644 --- a/packages/web/src/utils/format.ts +++ b/packages/web/src/utils/format.ts @@ -12,3 +12,14 @@ export const formatTime = (isoString: string) => { return `${ampm} ${displayHours}:${displayMinutes}`; }; + +export const formatDate = (isoString: string) => { + const time = new Date(isoString); + + const year = time.getFullYear(); + const month = time.getMonth() + 1; + const date = time.getDate(); + const day = ["일", "월", "화", "수", "목", "금", "토"][time.getDay()]; + + return `${year}년 ${month}월 ${date}일 (${day})`; +};