aboutsummaryrefslogtreecommitdiffstats
path: root/src/utils/hooks/use-article.ts
blob: f339f7fc2f818cb1c67839f8c89a578f13e83ba8 (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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
import { useEffect, useState } from 'react';
import useSWR from 'swr';
import {
  articleBySlugQuery,
  fetchAPI,
  getArticleFromRawData,
} from '../../services/graphql';
import type { Article, Maybe, RawArticle } from '../../types';

export type UseArticleConfig = {
  /**
   * A fallback article
   */
  fallback?: Article;
  /**
   * The article slug
   */
  slug?: string;
};

/**
 * Retrieve an article by slug.
 *
 * @param {UseArticleConfig} config - The config.
 * @returns {Article|undefined} The matching article if it exists.
 */
export const useArticle = ({
  slug,
  fallback,
}: UseArticleConfig): Article | undefined => {
  const { data } = useSWR(
    slug ? { query: articleBySlugQuery, variables: { slug } } : null,
    fetchAPI<RawArticle, typeof articleBySlugQuery>,
    {}
  );
  const [article, setArticle] = useState<Maybe<Article>>();

  useEffect(() => {
    const getArticle = async () => {
      if (data) {
        setArticle(await getArticleFromRawData(data.post));
      } else {
        setArticle(fallback);
      }
    };

    getArticle();
  }, [data, fallback]);

  return article;
};