Proyectos de Subversion LeadersLinked - SPA

Rev

Rev 2782 | Rev 3036 | 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
 
2904 stevensc 4
import { axios } from '@utils'
5
import { logout } from '@store/auth/auth.actions'
6
import { addNotification } from '@store/notification/notification.actions'
2210 stevensc 7
 
2774 stevensc 8
export function 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 }))
2430 stevensc 44
        if (error.message.includes('sesión')) dispatch(logout())
2212 stevensc 45
      })
707 stevensc 46
      .finally(() => setIsLoading(false))
47
  }
48
 
2375 stevensc 49
  const refetch = () => getResources(url)
50
 
2291 stevensc 51
  const mutate = (data) => setData(data)
52
 
707 stevensc 53
  useEffect(() => {
2224 stevensc 54
    getResources(url)
55
  }, [url])
707 stevensc 56
 
57
  return {
58
    data,
2291 stevensc 59
    mutate,
1363 stevensc 60
    isLoading,
2375 stevensc 61
    refetch
707 stevensc 62
  }
63
}