import { Button, IconButton, Input, Radio, RadioGroup } from "@mui/joy"; import { XIcon } from "lucide-react"; import React, { useState } from "react"; import { toast } from "react-hot-toast"; import { userServiceClient } from "@/grpcweb"; import useCurrentUser from "@/hooks/useCurrentUser"; import useLoading from "@/hooks/useLoading"; import { useTranslate } from "@/utils/i18n"; import { generateDialog } from "./Dialog"; interface Props extends DialogProps { onConfirm: () => void; } const expirationOptions = [ { label: "8 hours", value: 3600 * 8, }, { label: "1 month", value: 3600 * 24 * 30, }, { label: "Never", value: 0, }, ]; interface State { description: string; expiration: number; } const CreateAccessTokenDialog: React.FC = (props: Props) => { const { destroy, onConfirm } = props; const t = useTranslate(); const currentUser = useCurrentUser(); const [state, setState] = useState({ description: "", expiration: 3600 * 8, }); const requestState = useLoading(false); const setPartialState = (partialState: Partial) => { setState({ ...state, ...partialState, }); }; const handleDescriptionInputChange = (e: React.ChangeEvent) => { setPartialState({ description: e.target.value, }); }; const handleRoleInputChange = (e: React.ChangeEvent) => { setPartialState({ expiration: Number(e.target.value), }); }; const handleSaveBtnClick = async () => { if (!state.description) { toast.error("Description is required"); return; } try { await userServiceClient.createUserAccessToken({ name: currentUser.name, description: state.description, expiresAt: state.expiration ? new Date(Date.now() + state.expiration * 1000) : undefined, }); onConfirm(); destroy(); } catch (error: any) { toast.error(error.details); console.error(error); } }; return ( <>

Create access token

destroy()}>
Description *
Expiration *
{expirationOptions.map((option) => ( ))}
); }; function showCreateAccessTokenDialog(onConfirm: () => void) { generateDialog( { className: "create-access-token-dialog", dialogName: "create-access-token-dialog", }, CreateAccessTokenDialog, { onConfirm, }, ); } export default showCreateAccessTokenDialog;