summaryrefslogtreecommitdiffstats
path: root/src/components/ProjectPreview/ProjectPreview.tsx
blob: cba0b020c83c432584b5752b219324c03172d3c2 (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
52
53
54
55
import { t } from '@lingui/macro';
import { Project } from '@ts/types/app';
import { slugify } from '@utils/helpers/slugify';
import Image from 'next/image';
import Link from 'next/link';
import styles from './ProjectPreview.module.scss';

const ProjectPreview = ({ project }: { project: Project }) => {
  const { id, meta, tagline, title } = project;

  return (
    <Link href={`/projet/${project.slug}`}>
      <a className={styles.link}>
        <article className={styles.article}>
          <header>
            {meta.hasCover && (
              <div className={styles.cover}>
                <Image
                  src={`/projects/${id}.jpg`}
                  layout="fill"
                  objectFit="contain"
                  objectPosition="center"
                  alt={t`${title} picture`}
                />
              </div>
            )}
            <h2 className={styles.title}>{title}</h2>
          </header>
          {tagline && (
            <div
              className={styles.body}
              dangerouslySetInnerHTML={{ __html: tagline }}
            ></div>
          )}
          <footer className={styles.footer}>
            <dl className={styles.meta}>
              {meta.technologies && (
                <div className={styles.meta__item}>
                  <dt className="screen-reader-text">{t`Technologies:`}</dt>
                  {meta.technologies.map((techno) => (
                    <dd key={slugify(techno)} className={styles.techno}>
                      {techno}
                    </dd>
                  ))}
                </div>
              )}
            </dl>
          </footer>
        </article>
      </a>
    </Link>
  );
};

export default ProjectPreview;