blob: 91969b0a05359a819d78b606c08e2c8c7c71984c (
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={`${project.meta.title} picture`}
/>
</div>
)}
<h2 className={styles.title}>{project.meta.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;
|