summaryrefslogtreecommitdiff
path: root/src/components/Button.tsx
diff options
context:
space:
mode:
authorMatain <[email protected]>2022-06-12 23:34:56 +0800
committerMatain <[email protected]>2022-06-12 23:34:56 +0800
commitea5d7cf003eeef30cb7bbe789c6ba7f314bf1ce4 (patch)
treebff1bd7b0e8e8eb753d373b57f007bbe97f96c76 /src/components/Button.tsx
parent4fd2c8f646e48dd0c07d0c2041de52e9a4f8bc82 (diff)
parent38571da24ac54137564be5e41b7a409009e2ee10 (diff)
Merge branch 'master' of https://github.com/haishanh/yacd into haishanh-master
Diffstat (limited to 'src/components/Button.tsx')
-rw-r--r--src/components/Button.tsx10
1 files changed, 4 insertions, 6 deletions
diff --git a/src/components/Button.tsx b/src/components/Button.tsx
index 1725d1b..8125edc 100644
--- a/src/components/Button.tsx
+++ b/src/components/Button.tsx
@@ -17,7 +17,7 @@ type ButtonProps = {
isLoading?: boolean;
onClick?: (e: React.MouseEvent<HTMLButtonElement>) => unknown;
disabled?: boolean;
- kind?: 'primary' | 'minimal';
+ kind?: 'primary' | 'minimal' | 'circular';
className?: string;
title?: string;
} & ButtonInternalProps;
@@ -36,7 +36,7 @@ function Button(props: ButtonProps, ref: React.Ref<HTMLButtonElement>) {
...restProps
} = props;
const internalProps = { children, label, text, start };
- const internalOnClick = useCallback(
+ const internalOnClick = useCallback<React.MouseEventHandler<HTMLButtonElement>>(
(e) => {
if (isLoading) return;
onClick && onClick(e);
@@ -45,7 +45,7 @@ function Button(props: ButtonProps, ref: React.Ref<HTMLButtonElement>) {
);
const btnClassName = cx(
s0.btn,
- { [s0.minimal]: kind === 'minimal' },
+ { [s0.minimal]: kind === 'minimal', [s0.circular]: kind === 'circular' },
className
);
return (
@@ -76,9 +76,7 @@ function ButtonInternal({ children, label, text, start }: ButtonInternalProps) {
return (
<>
{start ? (
- <span className={s0.btnStart}>
- {typeof start === 'function' ? start() : start}
- </span>
+ <span className={s0.btnStart}>{typeof start === 'function' ? start() : start}</span>
) : null}
{children || label || text}
</>