aboutsummaryrefslogtreecommitdiff
path: root/FrontEnd/src/pages/setting/ChangeNicknameDialog.tsx
blob: 4d3185431a968dbd1812390a1995d57a0edd5b3b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import { getHttpUserClient } from "@/http/user";
import { useUserLoggedIn } from "@/services/user";

import OperationDialog from "@/views/common/dialog/OperationDialog";

export interface ChangeNicknameDialogProps {
  open: boolean;
  onClose: () => void;
}

export default function ChangeNicknameDialog(props: ChangeNicknameDialogProps) {
  const { open, onClose } = props;

  const user = useUserLoggedIn();

  return (
    <OperationDialog
      open={open}
      title="settings.dialogChangeNickname.title"
      inputs={[
        {
          key: "newNickname",
          type: "text",
          label: "settings.dialogChangeNickname.inputLabel",
        },
      ]}
      onProcess={({ newNickname }) => {
        return getHttpUserClient().patch(user.username, {
          nickname: newNickname as string,
        });
      }}
      onClose={onClose}
    />
  );
}