postiz/libraries/react-shared-libraries/src/form/button.tsx

63 lines
1.5 KiB
TypeScript

'use client';
import {
ButtonHTMLAttributes,
DetailedHTMLProps,
FC,
useEffect,
useRef,
useState,
} from 'react';
import { clsx } from 'clsx';
import ReactLoading from 'react-loading';
export const Button: FC<
DetailedHTMLProps<
ButtonHTMLAttributes<HTMLButtonElement>,
HTMLButtonElement
> & {
secondary?: boolean;
loading?: boolean;
innerClassName?: string;
}
> = ({ children, loading, innerClassName, ...props }) => {
const ref = useRef<HTMLButtonElement | null>(null);
const [height, setHeight] = useState<number | null>(null);
useEffect(() => {
setHeight(ref.current?.offsetHeight || 40);
}, []);
return (
<button
{...props}
type={props.type || 'button'}
ref={ref}
className={clsx(
(props.disabled || loading) && 'opacity-50 pointer-events-none',
`${
props.secondary ? 'bg-third' : 'bg-forth text-white'
} px-[24px] h-[40px] cursor-pointer items-center justify-center flex relative`,
props?.className
)}
>
{loading && (
<div className="absolute inset-0 flex items-center justify-center">
<ReactLoading
type="spin"
color="#fff"
width={height! / 2}
height={height! / 2}
/>
</div>
)}
<div
className={clsx(
innerClassName,
'flex-1 items-center justify-center flex',
loading && 'invisible'
)}
>
{children}
</div>
</button>
);
};