// Copyright 2024, Command Line Inc. // SPDX-License-Identifier: Apache-2.0 import clsx from "clsx"; import { Children, forwardRef, memo, ReactNode, useImperativeHandle, useRef } from "react"; import "./button.less"; interface ButtonProps extends React.ButtonHTMLAttributes { className?: string; children?: ReactNode; } const Button = memo( forwardRef(({ children, disabled, className = "", ...props }: ButtonProps, ref) => { const btnRef = useRef(null); useImperativeHandle(ref, () => btnRef.current as HTMLButtonElement); const childrenArray = Children.toArray(children); // 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 ( ); }) ); Button.displayName = "Button"; export { Button };