aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/ProjectPreview/ProjectPreview.tsx
blob: f5d2e8fb3ecb14901018623b6f7f088eabfad850 (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 }) => {
  return (
    <Link href={`/projet/${project.slug}`}>
      <a className={styles.link}>
        <article className={styles.article}>
          <header>
            {project.cover && (
              <div className={styles.cover}>
                <Image
                  src={project.cover}
                  layout="fill"
                  objectFit="contain"
                  objectPosition="center"
                  alt={t`${project.title} picture`}
                />
              </div>
            )}
            <h2 className={styles.title}>{project.title}</h2>
          </header>
          <div
            className={styles.body}
            dangerouslySetInnerHTML={{ __html: project.intro }}
          ></div>
          <footer>
            <dl className={styles.meta}>
              {project.meta.license && (
                <div className={styles.meta__item}>
                  <dt>{t`License:`}</dt>
                  <dd>{project.meta.license}</dd>
                </div>
              )}
              {project.meta.technologies && (
                <div className={styles.meta__item}>
                  <dt>{t`Technologies:`}</dt>
                  {project.meta.technologies.map((techno) => (
                    <dd key={slugify(techno)}>{techno}</dd>
                  ))}
                </div>
              )}
            </dl>
          </footer>
        </article>
      </a>
    </Link>
  );
};

export default ProjectPreview;