Я пытаюсь создать страницу аутентификации пользователя, используя React и Apollo. Я получаю, что мое событие не определено для события onClick
для следующего кода:
const Auth = props => {
const [email, setEmail] = useState('')
const [password, setPassword] = useState('')
const onSubmitHandler = async (login, e) => {
e.preventDefault()
const authResults = await login()
props.history.push('/')
}
return (
<Mutation
mutation={LOGIN}
variables={{ email, password }}
>
{(login, {data, error, loading}) => {
if(loading) return <div>...loading</div>
if(error) return <div>Error</div>
return (
<form onSubmit={onSubmitHandler}>
<fieldset>
<label htmlFor="email">
Email
</label>
<input
type="email"
id="email"
value={email}
onChange={e => {
setEmail(e.target.value)
}}
/>
</fieldset>
<fieldset>
<label htmlFor="password">
Password
</label>
<input
type="password"
id="password"
value={password}
onChange={e => {
setPassword(e.target.value)
}}
/>
</fieldset>
<button>Login</button>
</form>
)
}}
</Mutation>
)
Я попытался включить переменные в точке вызова следующим образом:
<form onSubmit={(login, e) => onSubmitHandler(login, e)}>
Но безрезультатно.
Изменить: Первоначальная проблема была решена, но когда я реорганизовал код для использования response-apollo-hooks, я продолжаю получать следующие ошибки:
Variable "$email" of required type "String!" was not provided
Variable "$password" of required type "String!" was not provided
Мои рефакторинговые коды следующие:
const [email, setEmail] = useState('')
const [password, setPassword] = useState('')
const variables = {
data: { email, password }
}
const login = useMutation(LOGIN_MUTATION, {
variables
})
const onSubmitHandler = async (login, e) => {
e.preventDefault()
const authResults = await login()
localStorage.setItem(AUTH_TOKEN, authResults.data.login.token);
props.history.push('/')
}
Графическая мутация
const LOGIN_MUTATION = gql`
mutation Login($email: String!, $password: String!) {
login(data: {
email: $email, password: $password
}
){
token
user {
id
}
}
}
`
Моя схема
логин (данные: LoginUserInput!): AuthPayload!