diff options
| author | kj_sh604 | 2026-03-15 16:19:35 -0400 |
|---|---|---|
| committer | kj_sh604 | 2026-03-15 16:19:35 -0400 |
| commit | 6ec259a0e71174651bae95d4628138bf6fd68742 (patch) | |
| tree | 5e33c6a5ec091ecabfcb257fdc7b6a88ed8754ac /packages/excalidraw/components/DialogActionButton.tsx | |
| parent | 16c8578b15c727f22921f8a80a56ee4d4e7f2272 (diff) | |
refactor: packages/
Diffstat (limited to 'packages/excalidraw/components/DialogActionButton.tsx')
| -rw-r--r-- | packages/excalidraw/components/DialogActionButton.tsx | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/packages/excalidraw/components/DialogActionButton.tsx b/packages/excalidraw/components/DialogActionButton.tsx new file mode 100644 index 0000000..0c4f9d5 --- /dev/null +++ b/packages/excalidraw/components/DialogActionButton.tsx @@ -0,0 +1,46 @@ +import clsx from "clsx"; +import type { ReactNode } from "react"; +import "./DialogActionButton.scss"; +import Spinner from "./Spinner"; + +interface DialogActionButtonProps { + label: string; + children?: ReactNode; + actionType?: "primary" | "danger"; + isLoading?: boolean; +} + +const DialogActionButton = ({ + label, + onClick, + className, + children, + actionType, + type = "button", + isLoading, + ...rest +}: DialogActionButtonProps & React.ButtonHTMLAttributes<HTMLButtonElement>) => { + const cs = actionType ? `Dialog__action-button--${actionType}` : ""; + + return ( + <button + className={clsx("Dialog__action-button", cs, className)} + type={type} + aria-label={label} + onClick={onClick} + {...rest} + > + {children && ( + <div style={isLoading ? { visibility: "hidden" } : {}}>{children}</div> + )} + <div style={isLoading ? { visibility: "hidden" } : {}}>{label}</div> + {isLoading && ( + <div style={{ position: "absolute", inset: 0 }}> + <Spinner /> + </div> + )} + </button> + ); +}; + +export default DialogActionButton; |
