Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 3406 | Rev 3416 | Ir a la última revisión | | Comparar con el anterior | Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
2611 stevensc 1
import React, { useEffect, useState } from 'react'
3407 stevensc 2
import { useDispatch, useSelector } from 'react-redux'
2611 stevensc 3
 
4
import { axios } from './utils'
2776 stevensc 5
import { useFetch } from '@hooks'
2611 stevensc 6
import { labelsAdapter } from './utils/labels'
7
import { setIntlLabels } from './redux/intl/intl.action'
3396 stevensc 8
import { setCrendentials } from './redux/auth/auth.actions'
2611 stevensc 9
 
10
import AppRoutes from './routes/routes'
3396 stevensc 11
import ErrorPage from './pages/error/error-page'
2611 stevensc 12
import Spinner from './components/UI/Spinner'
13
 
14
import './styles/globals.scss'
15
 
16
export default function App() {
17
  const [loading, setLoading] = useState(true)
18
  const [credentialsError, setCredentialsError] = useState(false)
19
  const { data: labels } = useFetch('/language')
3407 stevensc 20
  const { is_logged_in } = useSelector((state) => state.auth)
2611 stevensc 21
  const dispatch = useDispatch()
22
 
23
  const getCredentials = async () => {
24
    const response = await axios.get('/signin')
25
    const { data, success } = response.data
3396 stevensc 26
    if (!success) throw new Error('Error al obtener las credenciales')
2611 stevensc 27
    return data
28
  }
29
 
3396 stevensc 30
  useEffect(() => {
2611 stevensc 31
    setLoading(true)
3396 stevensc 32
 
2611 stevensc 33
    getCredentials()
3405 stevensc 34
      .then((credentials) => {
35
        window.localStorage.setItem('jwt', credentials.jwt)
3396 stevensc 36
        dispatch(setCrendentials(credentials))
2611 stevensc 37
      })
3399 stevensc 38
      .catch((error) => {
3405 stevensc 39
        console.error(error.message)
3399 stevensc 40
        setCredentialsError(true)
41
      })
2611 stevensc 42
      .finally(() => setLoading(false))
3407 stevensc 43
  }, [is_logged_in])
2611 stevensc 44
 
45
  useEffect(() => {
46
    dispatch(setIntlLabels(labelsAdapter(labels)))
47
  }, [labels])
48
 
49
  if (loading) {
50
    return <Spinner />
51
  }
52
 
53
  if (credentialsError) {
54
    return <ErrorPage />
55
  }
56
 
2803 stevensc 57
  return <AppRoutes />
2611 stevensc 58
}