diff options
| author | Mohamed Bassem <me@mbassem.com> | 2024-10-27 12:03:14 +0000 |
|---|---|---|
| committer | Mohamed Bassem <me@mbassem.com> | 2024-10-27 12:03:14 +0000 |
| commit | eb7da996a7c2d617d276f296cac07a6fd5648664 (patch) | |
| tree | 4711de55b6f5fed3ac0cf3539099a9c0f115647e /apps/web/components/settings/DeleteApiKey.tsx | |
| parent | 801ba36af5900c84af5a88dea37aa7d2f793fed9 (diff) | |
| download | karakeep-eb7da996a7c2d617d276f296cac07a6fd5648664.tar.zst | |
ui: Redesign the settings page and move it to its own layout
Diffstat (limited to 'apps/web/components/settings/DeleteApiKey.tsx')
| -rw-r--r-- | apps/web/components/settings/DeleteApiKey.tsx | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/apps/web/components/settings/DeleteApiKey.tsx b/apps/web/components/settings/DeleteApiKey.tsx new file mode 100644 index 00000000..e2334c44 --- /dev/null +++ b/apps/web/components/settings/DeleteApiKey.tsx @@ -0,0 +1,55 @@ +"use client"; + +import { useRouter } from "next/navigation"; +import { ActionButton } from "@/components/ui/action-button"; +import ActionConfirmingDialog from "@/components/ui/action-confirming-dialog"; +import { Button } from "@/components/ui/button"; +import { toast } from "@/components/ui/use-toast"; +import { api } from "@/lib/trpc"; +import { Trash } from "lucide-react"; + +export default function DeleteApiKey({ + name, + id, +}: { + name: string; + id: string; +}) { + const router = useRouter(); + const mutator = api.apiKeys.revoke.useMutation({ + onSuccess: () => { + toast({ + description: "Key was successfully deleted", + }); + router.refresh(); + }, + }); + + return ( + <ActionConfirmingDialog + title={"Delete API Key"} + description={ + <p> + Are you sure you want to delete the API key "{name}"? Any + service using this API key will lose access. + </p> + } + actionButton={(setDialogOpen) => ( + <ActionButton + type="button" + variant="destructive" + loading={mutator.isPending} + onClick={() => + mutator.mutate({ id }, { onSuccess: () => setDialogOpen(false) }) + } + > + Delete + </ActionButton> + )} + > + <Button variant="outline"> + <Trash size={18} color="red" /> + </Button> + </ActionConfirmingDialog> + ); +} |
