Compare commits
2 Commits
816c1c40c6
...
b169e975bb
| Author | SHA1 | Date | |
|---|---|---|---|
| b169e975bb | |||
| 661d053ea0 |
@@ -1,8 +1,8 @@
|
|||||||
'use client'
|
'use client'
|
||||||
|
|
||||||
import { useState } from 'react'
|
import { useState, useEffect } from 'react'
|
||||||
import { signIn } from 'next-auth/react'
|
import { signIn } from 'next-auth/react'
|
||||||
import { useRouter } from 'next/navigation'
|
import { useSearchParams } from 'next/navigation'
|
||||||
import { Eye } from 'lucide-react'
|
import { Eye } from 'lucide-react'
|
||||||
import { Button } from '@/components/ui/button'
|
import { Button } from '@/components/ui/button'
|
||||||
import { Card, CardContent, CardDescription, CardHeader, CardTitle } from '@/components/ui/card'
|
import { Card, CardContent, CardDescription, CardHeader, CardTitle } from '@/components/ui/card'
|
||||||
@@ -10,32 +10,29 @@ import { Input } from '@/components/ui/input'
|
|||||||
import { Label } from '@/components/ui/label'
|
import { Label } from '@/components/ui/label'
|
||||||
|
|
||||||
export default function LoginPage() {
|
export default function LoginPage() {
|
||||||
const router = useRouter()
|
const searchParams = useSearchParams()
|
||||||
const [email, setEmail] = useState('')
|
const [email, setEmail] = useState('')
|
||||||
const [password, setPassword] = useState('')
|
const [password, setPassword] = useState('')
|
||||||
const [error, setError] = useState('')
|
const [error, setError] = useState('')
|
||||||
const [loading, setLoading] = useState(false)
|
const [loading, setLoading] = useState(false)
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
const err = searchParams.get('error')
|
||||||
|
if (err === 'CredentialsSignin') {
|
||||||
|
setError('Email ou mot de passe incorrect')
|
||||||
|
}
|
||||||
|
}, [searchParams])
|
||||||
|
|
||||||
async function handleSubmit(e: React.FormEvent) {
|
async function handleSubmit(e: React.FormEvent) {
|
||||||
e.preventDefault()
|
e.preventDefault()
|
||||||
setError('')
|
setError('')
|
||||||
setLoading(true)
|
setLoading(true)
|
||||||
|
|
||||||
const result = await signIn('credentials', {
|
await signIn('credentials', {
|
||||||
email,
|
email,
|
||||||
password,
|
password,
|
||||||
redirect: false,
|
callbackUrl: '/',
|
||||||
})
|
})
|
||||||
|
|
||||||
setLoading(false)
|
|
||||||
|
|
||||||
if (result?.error) {
|
|
||||||
setError('Email ou mot de passe incorrect')
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
router.push('/')
|
|
||||||
router.refresh()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
|||||||
Reference in New Issue
Block a user