2024-09-18 07:38:17 +02:00
|
|
|
// Copyright 2024, Command Line Inc.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2024-06-18 06:50:33 +02:00
|
|
|
import clsx from "clsx";
|
2024-10-27 21:22:06 +01:00
|
|
|
import { forwardRef, memo, ReactNode, useImperativeHandle, useRef } from "react";
|
2024-09-18 07:38:17 +02:00
|
|
|
|
2024-11-22 01:05:04 +01:00
|
|
|
import "./button.scss";
|
2024-05-15 01:53:03 +02:00
|
|
|
|
2024-06-18 06:50:33 +02:00
|
|
|
interface ButtonProps extends React.ButtonHTMLAttributes<HTMLButtonElement> {
|
2024-05-15 01:53:03 +02:00
|
|
|
className?: string;
|
2024-09-18 07:38:17 +02:00
|
|
|
children?: ReactNode;
|
2024-10-27 21:22:06 +01:00
|
|
|
as?: keyof JSX.IntrinsicElements | React.ComponentType<any>;
|
2024-05-15 01:53:03 +02:00
|
|
|
}
|
|
|
|
|
2024-09-18 07:38:17 +02:00
|
|
|
const Button = memo(
|
2024-10-27 21:22:06 +01:00
|
|
|
forwardRef<HTMLButtonElement, ButtonProps>(
|
|
|
|
({ children, disabled, className = "", as: Component = "button", ...props }: ButtonProps, ref) => {
|
|
|
|
const btnRef = useRef<HTMLButtonElement>(null);
|
|
|
|
useImperativeHandle(ref, () => btnRef.current as HTMLButtonElement);
|
|
|
|
|
|
|
|
// Check if the className contains any of the categories: solid, outlined, or ghost
|
|
|
|
const containsButtonCategory = /(solid|outline|ghost)/.test(className);
|
|
|
|
// If no category is present, default to 'solid'
|
|
|
|
const categoryClassName = containsButtonCategory ? className : `solid ${className}`;
|
|
|
|
|
|
|
|
// Check if the className contains any of the color options: green, grey, red, or yellow
|
|
|
|
const containsColor = /(green|grey|red|yellow)/.test(categoryClassName);
|
|
|
|
// If no color is present, default to 'green'
|
|
|
|
const finalClassName = containsColor ? categoryClassName : `green ${categoryClassName}`;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Component
|
|
|
|
ref={btnRef}
|
|
|
|
tabIndex={disabled ? -1 : 0}
|
|
|
|
className={clsx("button", finalClassName)}
|
|
|
|
disabled={disabled}
|
|
|
|
{...props}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</Component>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
)
|
2024-09-18 07:38:17 +02:00
|
|
|
);
|
2024-05-15 01:53:03 +02:00
|
|
|
|
2024-09-27 03:21:28 +02:00
|
|
|
Button.displayName = "Button";
|
|
|
|
|
2024-05-15 01:53:03 +02:00
|
|
|
export { Button };
|