1
Fork 0
mirror of https://github.com/pds-nest/nest.git synced 2024-11-22 21:14:18 +00:00
pds-2021-g2-nest/nest_frontend/hooks/useBackendImmediately.js

30 lines
909 B
JavaScript
Raw Normal View History

2021-05-11 14:38:56 +00:00
import useBackend from "./useBackend"
2021-05-07 23:40:49 +00:00
import { useEffect } from "react"
/**
2021-05-11 14:38:56 +00:00
* Like {@link useBackend}, but runs as soon as the component is rendered.
2021-05-07 23:40:49 +00:00
*
* @param fetchData - The function to use when fetching data.
* @param method - The HTTP method to use.
* @param path - The HTTP path to fetch the data at.
* @param body - The body of the HTTP request (it will be JSONified before being sent).
* @param init - Additional `init` parameters to pass to `fetch`.
*/
2021-05-11 14:38:56 +00:00
export default function useBackendImmediately(fetchData, method, path, body, init) {
const { data, error, loading, fetchNow } = useBackend(fetchData, method, path, body, init)
2021-05-07 23:40:49 +00:00
useEffect(
() => {
2021-05-11 14:37:15 +00:00
if(!(
loading || data || error
)) {
2021-05-07 23:40:49 +00:00
fetchNow()
}
},
2021-05-11 14:37:15 +00:00
[data, error, loading, fetchNow],
2021-05-07 23:40:49 +00:00
)
2021-05-11 14:37:15 +00:00
return { data, error, loading, fetchNow }
2021-05-07 23:40:49 +00:00
}