import { useRef } from 'react'; import { Form, FormInput, FormButtons, PasswordField, Button } from 'react-basics'; import useApi from 'hooks/useApi'; import { useMutation } from '@tanstack/react-query'; import { getClientAuthToken } from 'lib/client'; import styles from './UserPasswordForm.module.css'; import useUser from 'hooks/useUser'; export default function UserPasswordForm({ onSave, onClose, userId }) { const { user: { id }, } = useUser(); const isCurrentUser = !userId || id === userId; const url = isCurrentUser ? `/users/${id}/password` : `/users/${id}`; const { post } = useApi(getClientAuthToken()); const { mutate, error, isLoading } = useMutation(data => post(url, data)); const ref = useRef(null); const handleSubmit = async data => { const payload = isCurrentUser ? data : { password: data.newPassword, }; mutate(payload, { onSuccess: async () => { onSave(); ref.current.reset(); }, }); }; const samePassword = value => { if (value !== ref?.current?.getValues('newPassword')) { return "Passwords don't match"; } return true; }; return (
); }