Skip to content

Commit

Permalink
feat: Input 컴포넌트 및 스토리북 추가
Browse files Browse the repository at this point in the history
  • Loading branch information
semnil5202 committed Apr 18, 2024
1 parent 859ea2f commit e7deac2
Show file tree
Hide file tree
Showing 2 changed files with 97 additions and 0 deletions.
30 changes: 30 additions & 0 deletions src/components/Input/Input.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
import styled from '@emotion/styled';
import { HTMLAttributes } from 'react';

import { convertCSS } from '../../utils/convertCSS';

interface Props extends HTMLAttributes<HTMLInputElement> {
width?: string | number;
height?: string | number;
padding?: string;
}

const Input = styled.input<Props>`
box-sizing: border-box;
width: ${({ width }) => (width && convertCSS(width)) || '100%'};
height: ${({ height }) => (height && convertCSS(height)) || '44px'};
border-radius: 6px;
padding: ${({ padding }) => padding || '11px 16px'};
font-size: ${({ theme }) => theme.font.suit14r.fontSize}px;
font-weight: ${({ theme }) => theme.font.suit14r.fontWeight};
border: 1px solid ${({ theme }) => theme.color.l2};
outline: none;
color: ${({ theme }) => theme.color.b4};
background: ${({ theme }) => theme.color.w1};
&:focus {
border-color: ${({ theme }) => theme.color.c1};
}
`;

export default Input;
67 changes: 67 additions & 0 deletions src/stories/Input.stories.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,67 @@
import { Meta, StoryObj } from '@storybook/react';

import Input from '../components/Input/Input';
import { ChangeEvent, useEffect, useState } from 'react';

const meta = {
title: 'Components/Input',
component: Input,
tags: ['autodocs'],
argTypes: {
width: {
control: 'text',
description: 'Input 컴포넌트의 넓이를 지정합니다.',
},
height: {
control: 'text',
description: 'Input 컴포넌트의 높이를 지정합니다.',
},
padding: {
control: 'text',
description: 'Input 컴포넌트 padding을 설정합니다.',
},
value: {
control: 'text',
description: 'Input 컴포넌트의 텍스트를 나타내는 값입니다.',
},
onChange: {
control: false,
description:
'Input 컴포넌트의 value를 변경할 수 있는 onChange 함수입니다.',
},
},
} as Meta<typeof Input>;

export default meta;
type Story = StoryObj<typeof Input>;

export const Default: Story = {
args: {
width: '100%',
height: '44px',
padding: '11px 16px',
value: 'input',
},
render: ({ value, width, height, padding }) => {
const userInput = value as string;
const [input, setInput] = useState<string>(userInput);

useEffect(() => {
setInput(userInput);
}, [userInput]);

return (
<>
<Input
value={input}
width={width}
height={height}
padding={padding}
onChange={(e: ChangeEvent<HTMLInputElement>) =>
setInput(e.target.value)
}
/>
</>
);
},
};

0 comments on commit e7deac2

Please sign in to comment.