2020-07-22 14:20:10 +03:00
|
|
|
import React, { ComponentType } from 'react';
|
2019-12-07 21:43:08 +02:00
|
|
|
import clsx from 'clsx';
|
2020-07-22 14:20:10 +03:00
|
|
|
|
2019-12-07 21:02:00 +02:00
|
|
|
import { COLOR_GREEN } from 'app/components/ui';
|
|
|
|
import { Color } from 'app/components/ui';
|
2016-05-02 10:15:42 +03:00
|
|
|
|
2019-12-09 09:47:51 +02:00
|
|
|
import buttons from '../buttons.scss';
|
2016-05-02 12:20:50 +03:00
|
|
|
|
2020-07-22 14:20:10 +03:00
|
|
|
interface Props extends React.ButtonHTMLAttributes<HTMLButtonElement> {
|
|
|
|
block?: boolean;
|
|
|
|
small?: boolean;
|
|
|
|
loading?: boolean;
|
|
|
|
className?: string;
|
|
|
|
color?: Color;
|
|
|
|
disabled?: boolean;
|
|
|
|
component?: string | React.ComponentType<any>;
|
|
|
|
}
|
|
|
|
|
|
|
|
const Button: ComponentType<Props> = ({
|
|
|
|
color = COLOR_GREEN,
|
|
|
|
block,
|
|
|
|
small,
|
|
|
|
disabled,
|
|
|
|
className,
|
|
|
|
loading,
|
|
|
|
component: ComponentProp = 'button',
|
|
|
|
...restProps
|
|
|
|
}) => (
|
|
|
|
<ComponentProp
|
|
|
|
className={clsx(
|
|
|
|
buttons[color],
|
|
|
|
{
|
|
|
|
[buttons.loading]: loading,
|
|
|
|
[buttons.block]: block,
|
|
|
|
[buttons.smallButton]: small,
|
|
|
|
[buttons.disabled]: disabled,
|
|
|
|
},
|
2020-05-24 02:08:24 +03:00
|
|
|
className,
|
2020-07-22 14:20:10 +03:00
|
|
|
)}
|
|
|
|
disabled={disabled}
|
|
|
|
{...restProps}
|
|
|
|
/>
|
|
|
|
);
|
2016-05-02 10:15:42 +03:00
|
|
|
|
2020-07-22 14:20:10 +03:00
|
|
|
export default Button;
|