2024-05-15 01:53:03 +02:00
|
|
|
// Copyright 2024, Command Line Inc.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
|
|
import { clsx } from "clsx";
|
2024-05-28 21:12:28 +02:00
|
|
|
import * as React from "react";
|
2024-05-15 01:53:03 +02:00
|
|
|
|
|
|
|
import "./button.less";
|
|
|
|
|
|
|
|
interface ButtonProps {
|
|
|
|
children: React.ReactNode;
|
|
|
|
onClick?: (e: React.MouseEvent<HTMLButtonElement>) => void;
|
|
|
|
disabled?: boolean;
|
|
|
|
leftIcon?: React.ReactNode;
|
|
|
|
rightIcon?: React.ReactNode;
|
|
|
|
style?: React.CSSProperties;
|
|
|
|
autoFocus?: boolean;
|
|
|
|
className?: string;
|
|
|
|
termInline?: boolean;
|
|
|
|
title?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
class Button extends React.Component<ButtonProps> {
|
|
|
|
static defaultProps = {
|
|
|
|
style: {},
|
|
|
|
className: "primary",
|
|
|
|
};
|
|
|
|
|
|
|
|
handleClick(e) {
|
|
|
|
if (this.props.onClick && !this.props.disabled) {
|
|
|
|
this.props.onClick(e);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
render() {
|
|
|
|
const { leftIcon, rightIcon, children, disabled, style, autoFocus, termInline, className, title } = this.props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<button
|
|
|
|
className={clsx("wave-button", { disabled }, { "term-inline": termInline }, className)}
|
|
|
|
onClick={this.handleClick.bind(this)}
|
|
|
|
disabled={disabled}
|
|
|
|
style={style}
|
|
|
|
autoFocus={autoFocus}
|
|
|
|
title={title}
|
|
|
|
>
|
|
|
|
{leftIcon && <span className="icon-left">{leftIcon}</span>}
|
|
|
|
{children}
|
|
|
|
{rightIcon && <span className="icon-right">{rightIcon}</span>}
|
|
|
|
</button>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export { Button };
|
|
|
|
export type { ButtonProps };
|