mirror of
				https://github.com/Yidadaa/ChatGPT-Next-Web.git
				synced 2025-10-25 09:50:40 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import * as React from "react";
 | |
| 
 | |
| import styles from "./button.module.scss";
 | |
| import { CSSProperties } from "react";
 | |
| 
 | |
| export type ButtonType = "primary" | "danger" | null;
 | |
| 
 | |
| export function IconButton(props: {
 | |
|   onClick?: () => void;
 | |
|   icon?: JSX.Element;
 | |
|   type?: ButtonType;
 | |
|   text?: string;
 | |
|   bordered?: boolean;
 | |
|   shadow?: boolean;
 | |
|   className?: string;
 | |
|   title?: string;
 | |
|   disabled?: boolean;
 | |
|   tabIndex?: number;
 | |
|   autoFocus?: boolean;
 | |
|   style?: CSSProperties;
 | |
|   aria?: string;
 | |
| }) {
 | |
|   return (
 | |
|     <button
 | |
|       className={
 | |
|         styles["icon-button"] +
 | |
|         ` ${props.bordered && styles.border} ${props.shadow && styles.shadow} ${
 | |
|           props.className ?? ""
 | |
|         } clickable ${styles[props.type ?? ""]}`
 | |
|       }
 | |
|       onClick={props.onClick}
 | |
|       title={props.title}
 | |
|       disabled={props.disabled}
 | |
|       role="button"
 | |
|       tabIndex={props.tabIndex}
 | |
|       autoFocus={props.autoFocus}
 | |
|       style={props.style}
 | |
|       aria-label={props.aria}
 | |
|     >
 | |
|       {props.icon && (
 | |
|         <div
 | |
|           aria-label={props.text || props.title}
 | |
|           className={
 | |
|             styles["icon-button-icon"] +
 | |
|             ` ${props.type === "primary" && "no-dark"}`
 | |
|           }
 | |
|         >
 | |
|           {props.icon}
 | |
|         </div>
 | |
|       )}
 | |
| 
 | |
|       {props.text && (
 | |
|         <div
 | |
|           aria-label={props.text || props.title}
 | |
|           className={styles["icon-button-text"]}
 | |
|         >
 | |
|           {props.text}
 | |
|         </div>
 | |
|       )}
 | |
|     </button>
 | |
|   );
 | |
| }
 |