diff options
author | eug-vs <eug-vs@keemail.me> | 2021-03-14 05:43:24 +0300 |
---|---|---|
committer | eug-vs <eug-vs@keemail.me> | 2021-03-14 05:43:24 +0300 |
commit | 8e907e75ea1efa555ba66332b73d2f54283331c6 (patch) | |
tree | f7879bf46b0bb82b37e77eb827eb2ca3b9fa8211 /src | |
parent | fcf3c87195e9e58af9c2c4f2ae45b2a03c8d2677 (diff) | |
download | commercel-ui-8e907e75ea1efa555ba66332b73d2f54283331c6.tar.gz |
feat: add Input component
Diffstat (limited to 'src')
-rw-r--r-- | src/components/Button.tsx | 28 | ||||
-rw-r--r-- | src/components/Input.tsx | 21 |
2 files changed, 35 insertions, 14 deletions
diff --git a/src/components/Button.tsx b/src/components/Button.tsx index bf98755..b715ba9 100644 --- a/src/components/Button.tsx +++ b/src/components/Button.tsx @@ -1,14 +1,13 @@ import React, { useCallback } from 'react'; import { useHistory } from 'react-router-dom'; -export type Props = Partial<{ - onClick: () => void; - route: string; - variant: 'contained' | 'outlined'; - size: 'sm' | 'md' | 'lg'; - children: string; -}> - +export interface Props extends React.ButtonHTMLAttributes<HTMLButtonElement> { + onClick?: () => void; + route?: string; + variant?: 'contained' | 'outlined'; + size?: 'sm' | 'md' | 'lg'; + children?: string; +} const variants = { contained: 'bg-black text-white', @@ -21,18 +20,19 @@ const sizes = { sm: 'p-3', }; -const Button: React.FC<Props> = ({ onClick, route, variant = 'contained', size = 'md', children }) => { +const style = 'm-3 font-bold tracking-wide hover:underline focus:outline-none border-2 border-black'; + +const Button: React.FC<Props> = ({ onClick, route, variant = 'contained', size = 'md', type = 'button', ...props }) => { const history = useHistory(); const navigateRoute = useCallback(() => history.push(route || '/'), [route, history]); return ( <button - type="button" + type={type} onClick={route ? navigateRoute : onClick} - className={`m-3 font-bold tracking-wide hover:underline focus:outline-none border-2 border-black ${variants[variant]} ${sizes[size]}`} - > - {children} - </button> + className={`${style} ${variants[variant]} ${sizes[size]}`} + {...props} + /> ); }; diff --git a/src/components/Input.tsx b/src/components/Input.tsx new file mode 100644 index 0000000..69b97a2 --- /dev/null +++ b/src/components/Input.tsx @@ -0,0 +1,21 @@ +import React from 'react'; + +export interface Props extends React.InputHTMLAttributes<HTMLInputElement> { + label?: string; +} + +const Input: React.FC<Props> = ({ label, ...props }) => { + return ( + <div className="m-2 mb-4 flex flex-col"> + <label htmlFor={props?.name} className="mb-1 text-gray-700">{label}</label> + <input + id={props?.name} + placeholder={label} + className="p-2 border-2 border-black focus:outline-none" + {...props} + /> + </div> + ); +}; + +export default Input; |