diff options
Diffstat (limited to 'src/components/Widgets/RecentPosts/RecentPosts.tsx')
| -rw-r--r-- | src/components/Widgets/RecentPosts/RecentPosts.tsx | 63 | 
1 files changed, 63 insertions, 0 deletions
| diff --git a/src/components/Widgets/RecentPosts/RecentPosts.tsx b/src/components/Widgets/RecentPosts/RecentPosts.tsx new file mode 100644 index 0000000..1569284 --- /dev/null +++ b/src/components/Widgets/RecentPosts/RecentPosts.tsx @@ -0,0 +1,63 @@ +import { t } from '@lingui/macro'; +import { getPublishedPosts } from '@services/graphql/queries'; +import { ArticlePreview } from '@ts/types/articles'; +import Image from 'next/image'; +import Link from 'next/link'; +import { useRouter } from 'next/router'; +import useSWR from 'swr'; +import styles from './RecentPosts.module.scss'; + +const RecentPosts = () => { +  const { data, error } = useSWR('/recent-posts', () => +    getPublishedPosts({ first: 3 }) +  ); +  const { locale } = useRouter(); +  const dateOptions: Intl.DateTimeFormatOptions = { +    day: 'numeric', +    month: 'long', +    year: 'numeric', +  }; + +  const getPost = (post: ArticlePreview) => { +    return ( +      <li key={post.id} className={styles.item}> +        <Link href={`/article/${post.slug}`}> +          <a className={styles.link}> +            <article className={styles.article}> +              {post.featuredImage && +                Object.keys(post.featuredImage).length > 0 && ( +                  <div className={styles.cover}> +                    <Image +                      src={post.featuredImage.sourceUrl} +                      alt={post.featuredImage.altText} +                      layout="fill" +                      objectFit="contain" +                    /> +                  </div> +                )} +              <h3 className={styles.title}>{post.title}</h3> +              <dl className={styles.meta}> +                <dt>{t`Published on:`}</dt> +                <dd> +                  {new Date(post.dates.publication).toLocaleDateString( +                    locale, +                    dateOptions +                  )} +                </dd> +              </dl> +            </article> +          </a> +        </Link> +      </li> +    ); +  }; + +  if (error) return <div>{t`Failed to load.`}</div>; +  if (!data) return <div>{t`Loading...`}</div>; + +  return ( +    <ul className={styles.list}>{data.posts.map((post) => getPost(post))}</ul> +  ); +}; + +export default RecentPosts; | 
