Proyectos de Subversion LeadersLinked - SPA

Rev

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

Rev Autor Línea Nro. Línea
707 stevensc 1
import { useState, useEffect } from 'react'
2211 stevensc 2
import { useDispatch } from 'react-redux'
707 stevensc 3
 
2210 stevensc 4
import { axios } from '@app/utils'
2211 stevensc 5
import { addNotification } from '@app/redux/notification/notification.actions'
2219 stevensc 6
import { logout } from '@app/redux/auth/auth.actions'
2210 stevensc 7
 
1622 stevensc 8
const useFetch = (url, defaultValue = {}) => {
707 stevensc 9
  const [data, setData] = useState(defaultValue)
1003 stevensc 10
  const [isLoading, setIsLoading] = useState(true)
2211 stevensc 11
  const dispatch = useDispatch()
707 stevensc 12
 
2210 stevensc 13
  const handleError = (response) => {
14
    const { success, data } = response.data
15
 
16
    if (!data) {
17
      return response.data
18
    }
19
 
20
    if (success === false) {
21
      const errorMessage =
22
        typeof data === 'string'
23
          ? data
24
          : Object.entries(data)
25
              .map(([key, value]) => `${key}: ${value}`)
26
              .join(', ')
27
      throw new Error(errorMessage)
28
    }
29
 
30
    return data
31
  }
32
 
2224 stevensc 33
  const getResources = (url) => {
2223 stevensc 34
    if (!url) return
35
 
1304 stevensc 36
    setIsLoading(true)
37
 
707 stevensc 38
    axios
1622 stevensc 39
      .get(url)
2210 stevensc 40
      .then((response) => handleError(response))
41
      .then((data) => setData(data))
2212 stevensc 42
      .catch((error) => {
2211 stevensc 43
        dispatch(addNotification({ style: 'danger', msg: error.message }))
2377 stevensc 44
        if (error.message.includes('sesión')) {
45
          dispatch(logout())
46
          window.location.reload()
47
        }
2212 stevensc 48
      })
707 stevensc 49
      .finally(() => setIsLoading(false))
50
  }
51
 
2375 stevensc 52
  const refetch = () => getResources(url)
53
 
2291 stevensc 54
  const mutate = (data) => setData(data)
55
 
707 stevensc 56
  useEffect(() => {
2224 stevensc 57
    getResources(url)
58
  }, [url])
707 stevensc 59
 
60
  return {
61
    data,
2291 stevensc 62
    mutate,
1363 stevensc 63
    isLoading,
2375 stevensc 64
    refetch
707 stevensc 65
  }
66
}
67
 
68
export default useFetch