diff options
| author | Armand Philippot <git@armandphilippot.com> | 2021-12-16 18:15:52 +0100 | 
|---|---|---|
| committer | Armand Philippot <git@armandphilippot.com> | 2021-12-16 18:19:56 +0100 | 
| commit | a4f865224e0e395c7e29bb3b7279a5101b554d2c (patch) | |
| tree | d0d91860bd7a00316132239341dadd1e5a9115ee | |
| parent | 6e2a66ca0f12e11c66d993ed22624cd4659b5f2e (diff) | |
chore: create post meta view for posts lists
| -rw-r--r-- | src/components/PostMeta/PostMeta.tsx | 79 | 
1 files changed, 79 insertions, 0 deletions
| diff --git a/src/components/PostMeta/PostMeta.tsx b/src/components/PostMeta/PostMeta.tsx new file mode 100644 index 0000000..776d912 --- /dev/null +++ b/src/components/PostMeta/PostMeta.tsx @@ -0,0 +1,79 @@ +import { t } from '@lingui/macro'; +import { ThematicPreview } from '@ts/types/taxonomies'; +import Link from 'next/link'; +import { useRouter } from 'next/router'; +import styles from './PostMeta.module.scss'; + +const PostMeta = ({ +  commentCount, +  publicationDate, +  updateDate, +  thematics, +}: { +  commentCount: number | null; +  publicationDate: string; +  updateDate: string; +  thematics: ThematicPreview[]; +}) => { +  const { locale } = useRouter(); +  const dateOptions: Intl.DateTimeFormatOptions = { +    day: 'numeric', +    month: 'long', +    year: 'numeric', +  }; + +  const getThematics = () => { +    return thematics.map((thematic) => { +      return ( +        <dd key={thematic.id}> +          <Link href={`/thematique/${thematic.slug}`}> +            <a>{thematic.title}</a> +          </Link> +        </dd> +      ); +    }); +  }; + +  const getCommentsCount = () => { +    switch (commentCount) { +      case null: +      case 0: +        return t`No comments`; +      case 1: +        return t`1 comment`; +      default: +        return t`${commentCount} comments`; +    } +  }; + +  return ( +    <dl className={styles.wrapper}> +      <div> +        <dt>{t`Published on`}</dt> +        <dd> +          {new Date(publicationDate).toLocaleDateString(locale, dateOptions)} +        </dd> +      </div> +      {publicationDate !== updateDate && ( +        <div> +          <dt>{t`Updated on`}</dt> +          <dd> +            {new Date(updateDate).toLocaleDateString(locale, dateOptions)} +          </dd> +        </div> +      )} +      {thematics.length > 0 && ( +        <div> +          <dt>{thematics.length > 1 ? t`Thematics` : t`Thematic`}</dt> +          {getThematics()} +        </div> +      )} +      <div> +        <dt>{t`Comments`}</dt> +        {getCommentsCount()} +      </div> +    </dl> +  ); +}; + +export default PostMeta; | 
