import { Button, IconButton } from "@mui/joy"; import copy from "copy-to-clipboard"; import { useEffect, useState } from "react"; import { toast } from "react-hot-toast"; import { userServiceClient } from "@/grpcweb"; import useCurrentUser from "@/hooks/useCurrentUser"; import { UserAccessToken } from "@/types/proto/api/v2/user_service"; import { useTranslate } from "@/utils/i18n"; import showCreateAccessTokenDialog from "../CreateAccessTokenDialog"; import { showCommonDialog } from "../Dialog/CommonDialog"; import Icon from "../Icon"; import LearnMore from "../LearnMore"; const listAccessTokens = async (name: string) => { const { accessTokens } = await userServiceClient.listUserAccessTokens({ name }); return accessTokens; }; const AccessTokenSection = () => { const t = useTranslate(); const currentUser = useCurrentUser(); const [userAccessTokens, setUserAccessTokens] = useState([]); useEffect(() => { listAccessTokens(currentUser.name).then((accessTokens) => { setUserAccessTokens(accessTokens); }); }, []); const handleCreateAccessTokenDialogConfirm = async () => { const accessTokens = await listAccessTokens(currentUser.name); setUserAccessTokens(accessTokens); }; const copyAccessToken = (accessToken: string) => { copy(accessToken); toast.success("Access token copied to clipboard"); }; const handleDeleteAccessToken = async (accessToken: string) => { showCommonDialog({ title: "Delete Access Token", content: `Are you sure to delete access token \`${getFormatedAccessToken(accessToken)}\`? You cannot undo this action.`, style: "danger", dialogName: "delete-access-token-dialog", onConfirm: async () => { await userServiceClient.deleteUserAccessToken({ name: currentUser.name, accessToken: accessToken }); setUserAccessTokens(userAccessTokens.filter((token) => token.accessToken !== accessToken)); }, }); }; const getFormatedAccessToken = (accessToken: string) => { return `${accessToken.slice(0, 4)}****${accessToken.slice(-4)}`; }; return ( <>

Access Tokens

A list of all access tokens for your account.

{userAccessTokens.map((userAccessToken) => ( ))}
Token Description Created At Expires At {t("common.delete")}
{getFormatedAccessToken(userAccessToken.accessToken)} copyAccessToken(userAccessToken.accessToken)} > {userAccessToken.description} {userAccessToken.issuedAt?.toLocaleString()} {userAccessToken.expiresAt?.toLocaleString() ?? "Never"} { handleDeleteAccessToken(userAccessToken.accessToken); }} >
); }; export default AccessTokenSection;