diff options
author | Eugene Sokolov <eug-vs@keemail.me> | 2020-08-10 13:51:11 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-08-10 13:51:11 +0300 |
commit | 823c82383424616bc7c2562e2a763321edb6050c (patch) | |
tree | 1d5220d68ab8ebb392c87038f2fc24cc72b28775 /src/hooks/APIClient.ts | |
parent | 70d20b76f042a519e8e164279dfa31b5ce027d44 (diff) | |
parent | 78218c0f3427ad79de003ac59cffb99b08f0ae7d (diff) | |
download | which-ui-823c82383424616bc7c2562e2a763321edb6050c.tar.gz |
Merge pull request #74 from which-ecosystem/fetching
SWR feat. crazy refactor
Diffstat (limited to 'src/hooks/APIClient.ts')
-rw-r--r-- | src/hooks/APIClient.ts | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/hooks/APIClient.ts b/src/hooks/APIClient.ts new file mode 100644 index 0000000..9563bd6 --- /dev/null +++ b/src/hooks/APIClient.ts @@ -0,0 +1,34 @@ +import useSWR, { responseInterface } from 'swr'; +import { User, Poll, Feedback } from 'which-types'; +import { get } from '../requests'; + + +interface Response<T> extends responseInterface<T, Error> { + data: T; +} + +const fetcher = (endpoint: string) => get(endpoint).then(response => response.data); + +const arrayOptions = { + initialData: [], + revalidateOnMount: true +}; + +export const useUser = (username: string | null): Response<User> => { + return useSWR( + username && `/users?username=${username}`, + (url: string) => get(url).then(response => response.data[0]) + ) as Response<User>; +}; + +export const useProfile = (id: string): Response<Poll[]> => { + return useSWR(id && `/profiles/${id}`, fetcher, arrayOptions) as Response<Poll[]>; +}; + +export const useFeed = (): Response<Poll[]> => { + return useSWR('/feed', fetcher, { ...arrayOptions, revalidateOnFocus: false }) as Response<Poll[]>; +}; + +export const useFeedback = (): Response<Feedback[]> => { + return useSWR('/feedback', fetcher, arrayOptions) as Response<Feedback[]>; +}; |