import { Button, IconButton } from "@mui/joy"; import axios from "axios"; import copy from "copy-to-clipboard"; import { useEffect, useState } from "react"; import { toast } from "react-hot-toast"; import useCurrentUser from "@/hooks/useCurrentUser"; import { ListUserAccessTokensResponse, UserAccessToken } from "@/types/proto/api/v2/user_service_pb"; 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 (username: string) => { const { data } = await axios.get(`/api/v2/users/${username}/access_tokens`); return data.accessTokens; }; const AccessTokenSection = () => { const t = useTranslate(); const currentUser = useCurrentUser(); const [userAccessTokens, setUserAccessTokens] = useState([]); useEffect(() => { listAccessTokens(currentUser.username).then((accessTokens) => { setUserAccessTokens(accessTokens); }); }, []); const handleCreateAccessTokenDialogConfirm = async () => { const accessTokens = await listAccessTokens(currentUser.username); 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 axios.delete(`/api/v2/users/${currentUser.id}/access_tokens/${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} {String(userAccessToken.issuedAt)} {String(userAccessToken.expiresAt ?? "Never")} { handleDeleteAccessToken(userAccessToken.accessToken); }} >
); }; export default AccessTokenSection;