ChatGPT-Next-Web/app/components/button.tsx

52 lines
1.1 KiB
TypeScript
Raw Normal View History

2023-03-09 17:01:40 +00:00
import * as React from "react";
2023-03-12 19:06:21 +00:00
import styles from "./button.module.scss";
2023-03-09 17:01:40 +00:00
2023-06-28 17:09:51 +00:00
export type ButtonType = "primary" | "danger" | null;
2023-03-09 17:01:40 +00:00
export function IconButton(props: {
onClick?: () => void;
2023-04-24 16:49:27 +00:00
icon?: JSX.Element;
2023-06-28 17:09:51 +00:00
type?: ButtonType;
2023-03-09 17:01:40 +00:00
text?: string;
bordered?: boolean;
shadow?: boolean;
2023-03-09 17:01:40 +00:00
className?: string;
2023-03-12 19:06:21 +00:00
title?: string;
2023-04-06 13:02:48 +00:00
disabled?: boolean;
tabIndex?: number;
autoFocus?: boolean;
2023-03-09 17:01:40 +00:00
}) {
return (
2023-04-06 13:02:48 +00:00
<button
2023-03-09 17:01:40 +00:00
className={
styles["icon-button"] +
` ${props.bordered && styles.border} ${props.shadow && styles.shadow} ${
props.className ?? ""
} clickable ${styles[props.type ?? ""]}`
2023-03-09 17:01:40 +00:00
}
2023-03-10 18:25:33 +00:00
onClick={props.onClick}
2023-03-12 19:06:21 +00:00
title={props.title}
2023-04-06 13:02:48 +00:00
disabled={props.disabled}
role="button"
tabIndex={props.tabIndex}
autoFocus={props.autoFocus}
2023-03-09 17:01:40 +00:00
>
2023-04-24 16:49:27 +00:00
{props.icon && (
<div
className={
styles["icon-button-icon"] +
` ${props.type === "primary" && "no-dark"}`
2023-04-24 16:49:27 +00:00
}
>
{props.icon}
</div>
)}
2023-03-09 17:01:40 +00:00
{props.text && (
<div className={styles["icon-button-text"]}>{props.text}</div>
)}
2023-04-06 13:02:48 +00:00
</button>
2023-03-09 17:01:40 +00:00
);
}