diff --git a/.changeset/short-hats-drop.md b/.changeset/short-hats-drop.md new file mode 100644 index 00000000..3459ea94 --- /dev/null +++ b/.changeset/short-hats-drop.md @@ -0,0 +1,5 @@ +--- +'@sopt-makers/ui': patch +--- + +Tag 컴포넌트에 ClassName Prop을 추가해 커스텀 스타일이 가능케 합니다. diff --git a/apps/docs/src/stories/Tag.stories.tsx b/apps/docs/src/stories/Tag.stories.tsx index 43b8aab9..8ae547cf 100644 --- a/apps/docs/src/stories/Tag.stories.tsx +++ b/apps/docs/src/stories/Tag.stories.tsx @@ -1,37 +1,26 @@ -import { Meta, StoryObj } from "@storybook/react"; +import { Meta, StoryObj } from '@storybook/react'; -import { type HTMLAttributes } from "react"; -import { Tag } from "@sopt-makers/ui"; - -interface TagOwnProps extends HTMLAttributes { - children?: string; - size?: "sm" | "md" | "lg"; - shape?: "rect" | "pill"; - variant?: "default" | "primary" | "secondary"; - type?: "solid" | "line"; -} - -type TagStoryProps = TagOwnProps & { children: string }; +import { Tag, TagProps } from '@sopt-makers/ui'; export default { - title: "Components/Tag", + title: 'Components/Tag', component: Tag, - tags: ["autodocs"], + tags: ['autodocs'], argTypes: { size: { control: 'radio', options: ['sm', 'md', 'lg'] }, shape: { control: 'radio', options: ['rect', 'pill'] }, variant: { control: 'radio', options: ['default', 'primary', 'secondary'] }, type: { control: 'radio', options: ['solid', 'line'] }, - } -} as Meta; + }, +} as Meta; // 기본 태그 스토리 -export const Default: StoryObj = { +export const Default: StoryObj = { args: { - children: "Default Tag", - size: "sm", - shape: "rect", - variant: "default", - type: "solid", + children: 'Default Tag', + size: 'sm', + shape: 'rect', + variant: 'default', + type: 'solid', }, }; diff --git a/packages/ui/Tag/Tag.tsx b/packages/ui/Tag/Tag.tsx index b86311be..017db606 100644 --- a/packages/ui/Tag/Tag.tsx +++ b/packages/ui/Tag/Tag.tsx @@ -4,6 +4,7 @@ import createTagStyle from './utils'; export interface TagProps extends HTMLAttributes { children?: React.ReactNode; + className?: string; size?: 'sm' | 'md' | 'lg'; shape?: 'rect' | 'pill'; variant?: 'default' | 'primary' | 'secondary'; @@ -11,11 +12,11 @@ export interface TagProps extends HTMLAttributes { } export const Tag = forwardRef((props, forwardedRef) => { - const { children, size = 'sm', shape = 'rect', variant = 'default', type = 'solid', ...restProps } = props; + const { children, className, size = 'sm', shape = 'rect', variant = 'default', type = 'solid', ...restProps } = props; const style = createTagStyle(type, variant, shape, size); return ( -
+
{children}
); diff --git a/packages/ui/Tag/utils.ts b/packages/ui/Tag/utils.ts index cfa73e49..809633a7 100644 --- a/packages/ui/Tag/utils.ts +++ b/packages/ui/Tag/utils.ts @@ -1,16 +1,11 @@ -import type { - TagShapeTheme, - TagSizeTheme, - TagTypeTheme, - TagVariantTheme, -} from "./types"; -import { sprinkles } from "./style.css"; +import type { TagShapeTheme, TagSizeTheme, TagTypeTheme, TagVariantTheme } from './types'; +import { sprinkles } from './style.css'; function createTagStyle( typeTheme: TagTypeTheme, variantTheme: TagVariantTheme, shapeTheme: TagShapeTheme, - sizeTheme: TagSizeTheme + sizeTheme: TagSizeTheme, ) { return sprinkles({ backgroundColor: `${variantTheme}-${typeTheme}`,