diff options
| author | MohamedBassem <me@mbassem.com> | 2024-02-16 21:26:24 +0000 |
|---|---|---|
| committer | MohamedBassem <me@mbassem.com> | 2024-02-17 11:49:39 +0000 |
| commit | 9235e9a6fbb364713105137b6bf5bba9d81ecd4c (patch) | |
| tree | 80bc7871ca2b043c110c61b796c46af91cb26e2f /packages/web/app/dashboard/settings/components/DeleteApiKey.tsx | |
| parent | 6febe13b3f4ad4eff3f205ece445b3577255bf41 (diff) | |
| download | karakeep-9235e9a6fbb364713105137b6bf5bba9d81ecd4c.tar.zst | |
ui: Change action buttons to show a spinner when the request is loading
Diffstat (limited to 'packages/web/app/dashboard/settings/components/DeleteApiKey.tsx')
| -rw-r--r-- | packages/web/app/dashboard/settings/components/DeleteApiKey.tsx | 23 |
1 files changed, 13 insertions, 10 deletions
diff --git a/packages/web/app/dashboard/settings/components/DeleteApiKey.tsx b/packages/web/app/dashboard/settings/components/DeleteApiKey.tsx index bc3e3c92..566136af 100644 --- a/packages/web/app/dashboard/settings/components/DeleteApiKey.tsx +++ b/packages/web/app/dashboard/settings/components/DeleteApiKey.tsx @@ -16,6 +16,8 @@ import { import { useRouter } from "next/navigation"; import { toast } from "@/components/ui/use-toast"; import { api } from "@/lib/trpc"; +import { ActionButton } from "@/components/ui/action-button"; +import { useState } from "react"; export default function DeleteApiKey({ name, @@ -24,18 +26,20 @@ export default function DeleteApiKey({ name: string; id: string; }) { + const [isDialogOpen, setDialogOpen] = useState(false); const router = useRouter(); const mutator = api.apiKeys.revoke.useMutation({ onSuccess: () => { toast({ description: "Key was successfully deleted", }); + setDialogOpen(false); router.refresh(); }, }); return ( - <Dialog> + <Dialog open={isDialogOpen} onOpenChange={setDialogOpen}> <DialogTrigger asChild> <Button variant="destructive"> <Trash className="size-5" /> @@ -55,15 +59,14 @@ export default function DeleteApiKey({ Close </Button> </DialogClose> - <DialogClose asChild> - <Button - type="button" - variant="destructive" - onClick={() => mutator.mutate({ id })} - > - Delete - </Button> - </DialogClose> + <ActionButton + type="button" + variant="destructive" + loading={mutator.isPending} + onClick={() => mutator.mutate({ id })} + > + Delete + </ActionButton> </DialogFooter> </DialogContent> </Dialog> |
