From b6c02bb897491e333b5c0d9c41ec27ff7eaa9700 Mon Sep 17 00:00:00 2001 From: leedohyun Date: Sat, 29 Jun 2024 11:18:23 +0900 Subject: [PATCH] =?UTF-8?q?feat:GoodsItem=20=EC=BB=B4=ED=8F=AC=EB=84=8C?= =?UTF-8?q?=ED=8A=B8=20=EA=B5=AC=ED=98=84?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.old.md | 6 ++--- src/stories/GoodsItem.css | 39 +++++++++++++++++++++++++++++++ src/stories/GoodsItem.stories.tsx | 34 +++++++++++++++++++++++++++ src/stories/GoodsItem.tsx | 36 ++++++++++++++++++++++++++++ 4 files changed, 112 insertions(+), 3 deletions(-) create mode 100644 src/stories/GoodsItem.css create mode 100644 src/stories/GoodsItem.stories.tsx create mode 100644 src/stories/GoodsItem.tsx diff --git a/README.old.md b/README.old.md index e63ba409f..3923295c8 100644 --- a/README.old.md +++ b/README.old.md @@ -28,9 +28,9 @@ FE 카카오 선물하기 1주차 과제: React 기초 - [o] isvalid props에 따라 input값 ui에서 오류 인지 - [o] input Element 기본 속성 모두 사용 - Image 컴포넌트 구현 - - [] ratio props에 따라 이미지 비율 설정 - - [] radius props에 따라 모서리 둥글게 적용 - - [] image Element 기본 속성 모두 사용 + - [o] ratio props에 따라 이미지 비율 설정 + - [o] radius props에 따라 모서리 둥글게 적용 + - [o] image Element 기본 속성 모두 사용 - GoodsItem 컴포넌트 구현 - [] default 형태와 ranking 형태 컴포넌트 구현 - [] Ranking 컴포넌트 랭킹 지정 diff --git a/src/stories/GoodsItem.css b/src/stories/GoodsItem.css new file mode 100644 index 000000000..381aaf346 --- /dev/null +++ b/src/stories/GoodsItem.css @@ -0,0 +1,39 @@ +.goods-item { + display: flex; + flex-direction: column; + align-items: center; + } + + .goods-item__image { + width: 100px; + height: 100px; + } + + .goods-item__details { + text-align: center; + } + + .goods-item__subtitle, + .goods-item__title, + .goods-item__amount { + margin: 4px 0; + } + + .ranking-goods-item { + position: relative; + } + + .ranking-goods-item__badge { + position: absolute; + top: 10px; + left: 10px; + background-color: pink; + border-radius: 50%; + padding: 5px 10px; + font-weight: bold; + } + + .ranking-goods-item--normal .ranking-goods-item__badge { + background-color: gray; + } + \ No newline at end of file diff --git a/src/stories/GoodsItem.stories.tsx b/src/stories/GoodsItem.stories.tsx new file mode 100644 index 000000000..8fda769a8 --- /dev/null +++ b/src/stories/GoodsItem.stories.tsx @@ -0,0 +1,34 @@ +import { Meta, Story } from '@storybook/react'; +import { GoodsItem, RankingGoodsItem, GoodsItemProps, RankingGoodsItemProps } from './GoodsItem'; + +export default { + title: 'COMMON/GoodsItem', + component: GoodsItem, + argTypes: { + imageSrc: { control: 'text' }, + subtitle: { control: 'text' }, + title: { control: 'text' }, + amount: { control: 'text' }, + rankingIndex: { control: { type: 'number', min: 1, max: 10, step: 1 } }, + }, +} as Meta; + +const Template: Story = (args) => ; +const RankingTemplate: Story = (args) => ; + +export const Default = Template.bind({}); +Default.args = { + imageSrc: 'https://t1.kakaocdn.net/friends/www/talk/kakaofriends_talk_2018.png', + subtitle: '카카오 프렌즈 특별 한정판', + title: '[특가] 카카오 프렌즈 특별 한정판 브라이트 쿠션', + amount: '100000000000원', +}; + +export const Ranking = RankingTemplate.bind({}); +Ranking.args = { + rankingIndex: 1, + imageSrc: 'https://t1.kakaocdn.net/friends/www/talk/kakaofriends_talk_2018.png', + subtitle: '카카오 프렌즈 특별 한정판', + title: '[특가] 카카오 프렌즈 특별 한정판 브라이트 쿠션', + amount: '10000원', +}; diff --git a/src/stories/GoodsItem.tsx b/src/stories/GoodsItem.tsx new file mode 100644 index 000000000..01e535481 --- /dev/null +++ b/src/stories/GoodsItem.tsx @@ -0,0 +1,36 @@ +import React from 'react'; +import './GoodsItem.css'; + +export interface GoodsItemProps { + imageSrc: string; + subtitle: string; + title: string; + amount: string; +} + +export interface RankingGoodsItemProps extends GoodsItemProps { + rankingIndex: number; +} + +export const GoodsItem: React.FC = ({ imageSrc, subtitle, title, amount }) => { + return ( +
+ {title} +
+
{subtitle}
+
{title}
+
{amount}
+
+
+ ); +}; + +export const RankingGoodsItem: React.FC = ({ rankingIndex, imageSrc, subtitle, title, amount }) => { + const rankingClass = rankingIndex <= 3 ? 'ranking-goods-item--top' : 'ranking-goods-item--normal'; + return ( +
+
{rankingIndex}
+ +
+ ); +};