aboutsummaryrefslogtreecommitdiffstats
path: root/src/utils/hooks/use-article.tsx
blob: 3a173ddf6799d6c36aa206c4926a82fecee2b895 (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
import { fetchAPI, getAPIUrl } from '@services/graphql/api';
import { getArticleFromRawData } from '@services/graphql/articles';
import { articleBySlugQuery } from '@services/graphql/articles.query';
import { Article } from '@ts/types/app';
import { RawArticle } from '@ts/types/raw-data';
import useSWR from 'swr';

/**
 * Retrieve an article by slug.
 *
 * @param {string} slug - The article slug.
 * @param {Article} fallback - A fallback article.
 * @returns {Article} The matching article.
 */
const useArticle = (slug: string, fallback: Article): Article => {
  const { data } = useSWR(
    { api: getAPIUrl(), query: articleBySlugQuery, variables: { slug } },
    fetchAPI<RawArticle, typeof articleBySlugQuery>
  );

  return data ? getArticleFromRawData(data.post) : fallback;
};

export default useArticle;