summaryrefslogtreecommitdiff
path: root/src/hooks/useAPIClient.ts
blob: b36cfec9e892f4a5317de0555cff524aba0bede6 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import useSWR, { responseInterface } from 'swr';
import _ from 'lodash';
import { get } from '../requests';

type Response<T> = responseInterface<T, Error>;

export interface Product {
  _id: string;
  name: string;
  description: string;
  price: number;
  quantity: number;
  specs: any;
  createdAt: string;
  updatedAt: string;
}

const fetcher = (endpoint: string) => get(endpoint).then(response => response.data);

export const useProducts = (options = {}): Response<Product[]> => {
  return useSWR('/products', fetcher, options);
};

export const useProduct = (_id: string): Response<Product> => {
  const { data: preloadedProducts } = useProducts({ revalidateOnMount: false });
  const result = useSWR(`/products/${_id}`, fetcher);
  if (!result.data && result.isValidating) {
    // If we are waiting for the first result, check if we can maybe
    // get the data from already cached list for the time-being
    const product = _.find(preloadedProducts, { _id });
    return { ...result, data: product };
  }
  return result;
};