From 63394bb1b47e7f48e1fdb9f8abf28dc3ec443227 Mon Sep 17 00:00:00 2001 From: Alex Gleason Date: Mon, 27 Mar 2023 16:59:55 -0500 Subject: [PATCH] AuthorizeRejectButtons: refactor button into a separate component --- .../components/authorize-reject-buttons.tsx | 80 ++++++++++++------- 1 file changed, 53 insertions(+), 27 deletions(-) diff --git a/app/soapbox/components/authorize-reject-buttons.tsx b/app/soapbox/components/authorize-reject-buttons.tsx index 81d25a63d9..d4d90732e4 100644 --- a/app/soapbox/components/authorize-reject-buttons.tsx +++ b/app/soapbox/components/authorize-reject-buttons.tsx @@ -1,3 +1,4 @@ +import clsx from 'clsx'; import React, { useEffect, useRef, useState } from 'react'; import { FormattedMessage } from 'react-intl'; @@ -10,7 +11,7 @@ interface IAuthorizeRejectButtons { } /** Buttons to approve or reject a pending item, usually an account. */ -const AuthorizeRejectButtons: React.FC = ({ onAuthorize, onReject, countdown = 0 }) => { +const AuthorizeRejectButtons: React.FC = ({ onAuthorize, onReject, countdown }) => { const [state, setState] = useState<'authorizing' | 'rejecting' | 'authorized' | 'rejected' | 'pending'>('pending'); const timeout = useRef(); @@ -68,35 +69,60 @@ const AuthorizeRejectButtons: React.FC = ({ onAuthorize default: return ( -
- - {(state === 'rejecting') && ( -
- )} -
-
- - {(state === 'authorizing') && ( -
- )} -
+ + ); } }; +interface IAuthorizeRejectButton { + theme: 'primary' | 'danger' + icon: string + action(): void + isLoading?: boolean + disabled?: boolean +} + +const AuthorizeRejectButton: React.FC = ({ theme, icon, action, isLoading, disabled }) => { + return ( +
+ + {(isLoading) && ( +
+ )} +
+ ); +}; + export { AuthorizeRejectButtons }; \ No newline at end of file