40 lines
1.0 KiB
JavaScript
40 lines
1.0 KiB
JavaScript
|
import { useCallback, useState } from "react";
|
||
|
import accountsService from "../../services/accountsService";
|
||
|
|
||
|
export const useAPIKeyRemoval = ({ key, onSuccess }) => {
|
||
|
const [removalInitiated, setRemovalInitiated] = useState(false);
|
||
|
const [removalError, setRemovalError] = useState(null);
|
||
|
|
||
|
const prompt = () => setRemovalInitiated(true);
|
||
|
const abort = () => setRemovalInitiated(false);
|
||
|
|
||
|
const confirm = useCallback(async () => {
|
||
|
setRemovalError(null);
|
||
|
try {
|
||
|
await accountsService.delete(`user/apikeys/${key.id}`);
|
||
|
setRemovalInitiated(false);
|
||
|
onSuccess();
|
||
|
} catch (err) {
|
||
|
let message = "There was an error processing your request. Please try again later.";
|
||
|
|
||
|
if (err.response) {
|
||
|
const response = await err.response.json();
|
||
|
|
||
|
if (response.message) {
|
||
|
message = response.message;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
setRemovalError(message);
|
||
|
}
|
||
|
}, [onSuccess, key]);
|
||
|
|
||
|
return {
|
||
|
removalInitiated,
|
||
|
removalError,
|
||
|
prompt,
|
||
|
abort,
|
||
|
confirm,
|
||
|
};
|
||
|
};
|