-
Notifications
You must be signed in to change notification settings - Fork 6.5k
Expand file tree
/
Copy pathindex.tsx
More file actions
72 lines (58 loc) · 1.64 KB
/
index.tsx
File metadata and controls
72 lines (58 loc) · 1.64 KB
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import { useTranslations } from 'next-intl';
import { useMemo } from 'react';
import type { ComponentProps, FC } from 'react';
import AvatarGroup from '@/components/Common/AvatarGroup';
import Preview from '@/components/Common/Preview';
import { Time } from '@/components/Common/Time';
import styles from './index.module.css';
type Author = {
fullName: string;
src: string;
};
type BlogPostCardProps = {
title: ComponentProps<typeof Preview>['title'];
type: Required<ComponentProps<typeof Preview>>['type'];
description?: string;
authors: Array<Author>;
date: Date;
};
const BlogPostCard: FC<BlogPostCardProps> = ({
title,
type,
description,
authors,
date,
}) => {
const t = useTranslations();
const avatars = useMemo(
() => authors.map(({ fullName, src }) => ({ alt: fullName, src })),
[authors]
);
return (
<article className={styles.container}>
<Preview
title={title}
type={type}
className={styles.preview}
width="auto"
height="auto"
/>
<p className={styles.subtitle}>{t(`components.common.card.${type}`)}</p>
<p aria-hidden="true" className={styles.title}>
{title}
</p>
{description && <p className={styles.description}>{description}</p>}
<footer className={styles.footer}>
<AvatarGroup avatars={avatars} />
<div className={styles.author}>
<p>{avatars.map(avatar => avatar.alt).join(', ')}</p>
<Time
date={date}
format={{ day: 'numeric', month: 'short', year: 'numeric' }}
/>
</div>
</footer>
</article>
);
};
export default BlogPostCard;