/* eslint-disable space-before-function-paren */
import React, { useState, useEffect } from 'react'
import Address from './Address/Address'
import Agreement from './Agreement/Agreement'
import DocumentScanner from './DocumentScanner/DocumentScanner'
import FinalSlip from './FinalSlip/FinalSlip'
import Fingerprint from './Fingerprint/Fingerprint'
import FormTwo from './FormTwo/FormTwo'
import IrisScan from './IrisScan/IrisScan'
import { useMutation } from 'react-query'
import PhotoCapture from './PhotoCapture/PhotoCapture'
import SubmitButton from '../../components/SubmitButton/SubmitButton'
import FormOne from './FormOne/FormOne'
import Home from '../Home/Home'
import {
validEmail,
validMobileNumber,
validPincode,
validString
} from '../../constants/RegEx'
import { createUser, sendMessage } from '../../services/apiservice'
import { useTranslation } from 'react-i18next'
import { ToastContainer, toast } from 'react-toastify'
import 'react-toastify/dist/ReactToastify.css'
import { userContext } from '../../context/User'
import { useNavigate } from 'react-router-dom'
import BackButton from '../../components/BackButton/BackButton'
import { initialUserData } from '../../constants/userData'
import * as cocoSsd from '@tensorflow-models/coco-ssd'
import * as tf from '@tensorflow/tfjs'
import Spinner from '../../components/Spinner/Spinner'
const Enrollment = () => {
const { t } = useTranslation()
const [page, setPage] = useState(0)
const { userData, setUserData } = userContext()
const navigate = useNavigate()
const [unverified, setUnverified] = useState(true)
const language = localStorage.getItem('i18nextLng')
const [model, setModel] = useState()
async function loadModel() {
try {
const model = await cocoSsd.load()
setModel(model)
console.log('setloadedModel')
} catch (err) {
console.log(err)
console.log('failed load model')
}
}
useEffect(() => {
tf.ready().then(() => {
loadModel()
})
}, [])
let predictions = []
async function predictionFunction() {
predictions = await model.detect(document.getElementById('img'))
if (predictions.length > 0) {
console.log(predictions)
console.log(predictions[0])
}
return predictions
}
const { mutate } = useMutation((payload) => createUser(payload), {
onSuccess: (data) => {
setConfirm.mutate({
mobile: `+91${userData.mobile}`,
id: data?.data?.result?._id
})
setPage(page + 1)
},
onLoading: () => {
return
},
onError: (error) => {
console.log(error)
if (error?.response?.data?.message === 'User already exists.') {
setUserData(initialUserData)
navigate('/error')
} else {
toast.error(t('SOMETHING_WENT_WRONG'))
}
}
})
const setConfirm = useMutation((payload) => {
sendMessage(payload)
})
let audio
const handleSubmit = () => {
if (page === 0) {
if (userData.indianResident === '') {
toast.error(t('PLEASE_SELECT_YOUR_RESIDENCY'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/select-residency-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/select-residency-hindi.mp3`
)
}
audio.play()
} else if (userData.name === '' || userData.name.length < 1) {
toast.error(t('PLEASE_ENTER_YOUR_NAME'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-name-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-name-hindi.mp3`
)
}
audio.play()
} else if (!validString.test(userData.name)) {
toast.error(t('PLEASE_ENTER_VALID_NAME'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-valid-name-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-valid-name-hindi.mp3`
)
}
audio.play()
} else if (userData.gender === '') {
toast.error(t('PLEASE_SELECT_YOUR_GENDER'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-your-gender-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-your-gender-hindi.mp3`
)
}
audio.play()
} else if (userData.dob === '') {
toast.error(t('PLEASE_SELECT_YOUR_DOB'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-dob-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-dob-hindi.mp3`
)
}
audio.play()
} else {
setPage(page + 1)
}
} else if (page === 1) {
if (userData.mobile === '') {
toast.error(t('PLEASE_ENTER_YOUR_MOBILE_NUMBER'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-mobile-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-mobile-hindi.mp3`
)
}
audio.play()
} else if (!validMobileNumber.test(userData.mobile)) {
toast.error(t('PLEASE_ENTER_VALID_MOBILE_NUMBER'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-valid-mobile-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-valid-mobile-hindi.mp3`
)
}
audio.play()
} else if (userData.email === '') {
toast.error(t('PLEASE_ENTER_YOUR_EMAIL'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-email-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-email-hindi.mp3`
)
}
audio.play()
} else if (!validEmail.test(userData.email)) {
toast.error(t('PLEASE_ENTER_VALID_EMAIL'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-valid-email-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-valid-email-hindi.mp3`
)
}
audio.play()
} else {
setPage(page + 1)
}
} else if (page === 2) {
if (userData.address.houseNo === '') {
toast.error(t('PLEASE_ENTER_YOUR_HOUSE_NUMBER'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-house-no-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-house-no-hindi.mp3`
)
}
audio.play()
} else if (userData.address.street === '') {
toast.error(t('PLEASE_ENTER_YOUR_STREET'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-street-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-street-hindi.mp3`
)
}
audio.play()
} else if (userData.address.locality === '') {
toast.error(t('PLEASE_ENTER_YOUR_LOCALITY'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-locality-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-locality-hindi.mp3`
)
}
audio.play()
} else if (userData.address.village === '') {
toast.error(t('PLEASE_ENTER_YOUR_VILLAGE'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-village-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-village-hindi.mp3`
)
}
audio.play()
} else if (userData.address.postOffice === '') {
toast.error(t('PLEASE_ENTER_YOUR_AREA_POST_OFFICE'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-post-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-post-hindi.mp3`
)
}
audio.play()
} else if (userData.address.pincode === '') {
toast.error(t('PLEASE_ENTER_YOUR_AREA_PINCODE'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-pin-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-pin-hindi.mp3`
)
}
audio.play()
} else if (!validPincode.test(userData.address.pincode)) {
toast.error(t('PLEASE_ENTER_VALID_PINCODE'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-valid-pin-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-enter-valid-pin-hindi.mp3`
)
}
audio.play()
} else if (!userData.address.state.name) {
toast.error(t('PLEASE_SELECT_YOUR_STATE'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-state-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-state-hindi.mp3`
)
}
audio.play()
} else if (!userData.address.district.name) {
toast.error(t('PLEASE_SELECT_YOUR_DISTRICT'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-district-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-district-hindi.mp3`
)
}
audio.play()
} else if (userData.address.landmark === '') {
toast.error(t('PLEASE_ENTER_NEAREST_LANDMARK'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-landmark-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-select-landmark-hindi.mp3`
)
}
audio.play()
} else {
setPage(page + 1)
}
} else if (page === 3) {
predictionFunction()
if (predictions.length === 0) {
toast.warning(t('PLEASE_WAIT'), {
timeout: 1000
})
}
setTimeout(() => {
if (predictions.length > 0) {
if (!userData.photo) {
toast.error(t('PLEASE_CAPTURE_PHOTOGRAPH'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-capture-photo-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-capture-photo-hindi.mp3`
)
}
audio.play()
} else if (
predictions[0].class === 'person' &&
predictions[0].score > 0.5
) {
setPage(page + 1)
} else {
toast.error(t('PLEASE_CAPTURE_CLEAR_PHOTOGRAPH'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-capture-clear-photo-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-capture-clear-photo-hindi.mp3`
)
}
audio.play()
}
} else {
toast.error(t('PLEASE_CAPTURE_CLEAR_PHOTOGRAPH'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-capture-clear-photo-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-capture-clear-photo-hindi.mp3`
)
}
audio.play()
}
}, 1000)
} else if (page === 4) {
if (!userData.documents.POI) {
toast.error(t('SCAN_YOUR_DOCUMENT'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/scan-documents-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/scan-documents-hindi.mp3`
)
}
audio.play()
} else {
setPage(page + 1)
}
} else if (page === 5) {
setPage(page + 1)
} else if (page === 6) {
setPage(page + 1)
} else if (page === 7) {
if (unverified) {
toast.error(t('PLEASE_VERIFY_OTP'))
if (language === 'en') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-verify-otp-english.mp3`
)
} else if (language === 'hi') {
audio = new Audio(
`${process.env.PUBLIC_URL}/assets/audios/please-verify-otp-hindi.mp3`
)
}
audio.play()
} else {
mutate({
indianResident: userData.indianResident,
name: userData.name,
gender: userData.gender,
dob: userData.dob,
mobile: userData.mobile,
email: userData.email,
address: userData.address,
photo: userData.photo,
documents: {
POI: userData.documents.POI,
POA: userData.documents.POA,
DOB: userData.documents.DOB
}
})
}
} else if (page === 8) {
setUserData(initialUserData)
navigate('/')
}
}
console.log(userData)
const conditionalComponent = () => {
switch (page) {
case 0:
return
case 1:
return
case 2:
return
case 3:
return
case 4:
return
case 5:
return
case 6:
return
case 7:
return (
)
case 8:
return
default:
return
}
}
const conditionalButton = () => {
switch (page) {
case 0:
return (
<>
{
setUserData(initialUserData)
navigate('/')
}}
/>
>
)
case 1:
case 2:
case 3:
case 4:
case 5:
case 6:
return (
<>
setPage(page - 1)} />
>
)
case 7:
return (
<>
setPage(page - 1)} />
>
)
case 8:
default:
return
}
}
return (
<>
{conditionalComponent()}
{conditionalButton()}
>
)
}
export default Enrollment