Skip to content

Commit

Permalink
Merge pull request #52 from SOPT-all/refactor/#51/Comment
Browse files Browse the repository at this point in the history
[Refactor/#51] λŒ“κΈ€ μ»΄ν¬λ„ŒνŠΈ
  • Loading branch information
Leeyoonji23 authored Jan 15, 2025
2 parents f237bdf + d6b76e1 commit 864a5b8
Show file tree
Hide file tree
Showing 6 changed files with 85 additions and 50 deletions.
1 change: 0 additions & 1 deletion src/asset/svg/IcMessage.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
import * as React from "react";
import type { SVGProps } from "react";
const SvgIcMessage = (props: SVGProps<SVGSVGElement>) => (
<svg
Expand Down
36 changes: 14 additions & 22 deletions src/common/component/Comment/Comment.css.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,10 @@
import { style } from "@vanilla-extract/css";
import { font, semanticColor } from "@style/styles.css";

export const commentContainer = style([
export const commentItem = style([
{
position: "relative",
display: "flex",
flexDirection: "column",
width: "33.5rem",
padding: "0.8rem 0rem",
alignItems: "flex-start",
gap: "0.4rem",
},
]);
Expand All @@ -16,23 +13,16 @@ export const containerOptionsIcon = style([
{
position: "absolute",
left: "31.1rem",
top: "0.8rem",
},
]);

export const commentItem = style([
{
display: "flex",
alignItems: "flex-start",
gap: "0.4rem",
},
]);

export const contentContainer = style([
{
flex: 1,
position: "relative",
display: "flex",
flexDirection: "column",
width: "33.5rem",
padding: "0.8rem 0rem",
gap: "0.4rem",
},
]);
Expand All @@ -45,6 +35,12 @@ export const header = style([
},
]);

export const profileImage = style({
width: "3.2rem",
height: "3.2rem",
borderRadius: "50%",
});

export const headerInfo = style([
{
display: "flex",
Expand Down Expand Up @@ -76,7 +72,7 @@ export const text = style([
color: semanticColor.text.normal,
fontWeight: "500",
lineHeight: "2.24rem",
letterSpacing: "-0.16rem",
letterSpacing: "-0.016rem",
padding: "0rem 1.1rem 0rem 4rem",
},
]);
Expand All @@ -91,11 +87,7 @@ export const replyContainer = style([
font.label01,
{
color: semanticColor.text.assistiveLight,
fontWeight: "500",
letterSpacing: "-0.024rem",
},
]);

export const profileImage = style({
width: "3.2rem",
height: "3.2rem",
borderRadius: "50%",
});
49 changes: 23 additions & 26 deletions src/common/component/Comment/Comment.tsx
Original file line number Diff line number Diff line change
@@ -1,46 +1,43 @@
import * as styles from "./Comment.css";
import { IcMessage, IcEllipses } from "@asset/svg";
import { IcEllipses, IcMessage } from "@asset/svg";

interface CommentData {
export interface CommentData {
id: number;
nickname: string;
breed: string;
petAge: number;
createdAt: string;
content: string;
createdAt: string;
isWriter: string;
profileImage: string;
}

interface CommentProps {
comments: CommentData[];
comment: CommentData;
}

const Comment = ({ comments }: CommentProps) => {
const Comment = ({ comment }: CommentProps) => {
return (
<div className={styles.commentContainer}>
{comments.map((comment) => (
<div key={comment.id} className={styles.commentItem}>
<div className={styles.contentContainer}>
<div className={styles.header}>
<img src={comment.profileImage} className={styles.profileImage} alt="ν”„λ‘œν•„ 이미지" />
<div className={styles.headerInfo}>
<IcEllipses className={styles.containerOptionsIcon} />
<span className={styles.nickname}>{comment.nickname}</span>
<span className={styles.meta}>
{comment.breed}Β·{comment.petAge}μ‚΄ Β· {comment.createdAt}
</span>
</div>
</div>
<div className={styles.commentItem}>
<div className={styles.contentContainer}>
<div className={styles.header}>
<img src={comment.profileImage} className={styles.profileImage} alt="ν”„λ‘œν•„ 이미지" />
<div className={styles.headerInfo}>
<IcEllipses className={styles.containerOptionsIcon} />
<span className={styles.nickname}>{comment.nickname}</span>
<span className={styles.meta}>
{comment.breed}Β·{comment.petAge}μ‚΄ Β· {comment.createdAt}
</span>
</div>
</div>

<p className={styles.text}>{comment.content}</p>
<p className={styles.text}>{comment.content}</p>

<div className={styles.replyContainer}>
<IcMessage />
<p>λ‹΅κΈ€μ“°κΈ°</p>
</div>
</div>
<div className={styles.replyContainer}>
<IcMessage />
<p>λ‹΅κΈ€μ“°κΈ°</p>
</div>
))}
</div>
</div>
);
};
Expand Down
17 changes: 17 additions & 0 deletions src/common/component/Comment/CommentList.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import Comment, { CommentData } from "./Comment";

interface CommentListProps {
comments: CommentData[];
}

const CommentList = ({ comments }: CommentListProps) => {
return (
<div style={{ margin: "2.4rem" }}>
{comments.map((comment) => (
<Comment key={comment.id} comment={comment} />
))}
</div>
);
};

export default CommentList;
6 changes: 5 additions & 1 deletion src/page/main/index/Main.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,8 @@ import Spacing from "@common/component/Spacing/Spacing";
import { Button } from "@common/component/Button";
import { IcTest } from "@asset/svg";
import SimpleBottomSheet from "@common/component/SimpleBottomSheet/SimpleBottomSheet";

import CommentList from "@common/component/Comment/CommentList";
import { mockComments } from "../../../shared/constant/mockComment";
const Main = () => {
return (
<>
Expand All @@ -25,6 +26,7 @@ const Main = () => {
<Button label="Button" size="medium" variant="outlinePrimary" disabled={false} />
<Button label="Button" size="large" variant="outlinePrimary" disabled={false} />
</div>

<div style={{ margin: "3rem", display: "flex", gap: "1rem" }}>
<Button label="Button" leftIcon={<IcTest />} size="medium" variant="solidPrimary" disabled={false} />
<Button label="Button" rightIcon={<IcTest />} size="medium" variant="solidPrimary" disabled={false} />
Expand All @@ -37,12 +39,14 @@ const Main = () => {
disabled={false}
/>
</div>

<span>main</span>
<SimpleBottomSheet />
<Spacing marginBottom="10" />
<Divider size="small" />
<Spacing marginBottom="10" />
<Divider />
<CommentList comments={mockComments} />
</>
);
};
Expand Down
26 changes: 26 additions & 0 deletions src/shared/constant/mockComment.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
/*λŒ“κΈ€ λ Œλ”λ§μš© λͺ©λ°μ΄ν„°μ˜ˆμš” μ§€μšΈμ˜ˆμ •μž…λ‹ˆλ‹€ */
export const mockComments = [
{
id: 1,
nickname: "λ¦¬νŠΈλ¦¬λ²„μ‚¬λž‘ν•΄",
breed: "κ³¨λ“ λ¦¬νŠΈλ¦¬λ²„",
petAge: 12,
content: "호흑기 문제일 수 μžˆλŠ”λ° λ‹€λ₯Έ 증상은 μ—†λ‚˜μš”?",
createdAt: "1μ‹œκ°„ μ „",
isWriter: "true",
profileImage:
"",
},
{
id: 2,
nickname: "λƒ₯λƒ₯이",
breed: "페λ₯΄μ‹œμ•ˆ",
petAge: 3,
content:
"κ°•μ•„μ§€κ·€μ—¬μ›Œ κ°•μ•„μ§€κ·€μ—¬μ›Œ κ°•μ•„μ§€κ·€μ—¬μ›Œ κ°•μ•„μ§€κ·€μ—¬μ›Œκ°•μ•„μ§€κ·€μ—¬μ›Œ κ°•μ•„μ§€κ·€μ—¬μ›Œκ°•μ•„μ§€κ·€μ—¬μ›Œ κ°•μ•„μ§€κ·€μ—¬μ›Œκ°•μ•„μ§€κ·€μ—¬μ›Œ κ°•μ•„μ§€κ·€μ—¬μ›Œκ°•μ•„μ§€κ·€μ—¬μ›Œ κ°•μ•„μ§€κ·€μ—¬μ›Œ",
createdAt: "2μ‹œκ°„ μ „",
isWriter: "true",
profileImage:
"",
},
];

0 comments on commit 864a5b8

Please sign in to comment.