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
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
import GithubIcon from '@assets/images/social-media/github.svg';
import GitlabIcon from '@assets/images/social-media/gitlab.svg';
import LinkedInIcon from '@assets/images/social-media/linkedin.svg';
import TwitterIcon from '@assets/images/social-media/twitter.svg';
import styles from './SocialMedia.module.scss';
import { ExpandableWidget } from '@components/WidgetParts';
import { useIntl } from 'react-intl';
const SocialMedia = ({
title,
github = false,
gitlab = false,
linkedin = false,
twitter = false,
}: {
title: string;
github?: boolean;
gitlab?: boolean;
linkedin?: boolean;
twitter?: boolean;
}) => {
const intl = useIntl();
const websites = [
{
id: 'github',
name: intl.formatMessage({
defaultMessage: 'Github',
description: 'SocialMedia: Github',
}),
url: 'https://github.com/ArmandPhilippot',
},
{
id: 'gitlab',
name: intl.formatMessage({
defaultMessage: 'Gitlab',
description: 'SocialMedia: Gitlab',
}),
url: 'https://gitlab.com/ArmandPhilippot',
},
{
id: 'linkedin',
name: intl.formatMessage({
defaultMessage: 'LinkedIn',
description: 'SocialMedia: LinkedIn',
}),
url: 'https://www.linkedin.com/in/armandphilippot',
},
{
id: 'twitter',
name: intl.formatMessage({
defaultMessage: 'Twitter',
description: 'SocialMedia: Twitter',
}),
url: 'https://twitter.com/ArmandPhilippot',
},
];
const getIcon = (id: string) => {
switch (id) {
case 'github':
return <GithubIcon className={styles.icon} />;
case 'gitlab':
return <GitlabIcon className={styles.icon} />;
case 'linkedin':
return <LinkedInIcon className={styles.icon} />;
case 'twitter':
return <TwitterIcon className={styles.icon} />;
default:
break;
}
};
const shouldDisplayLink = (id: string) => {
switch (id) {
case 'github':
return github;
case 'gitlab':
return gitlab;
case 'linkedin':
return linkedin;
case 'twitter':
return twitter;
default:
break;
}
};
const items = websites.map((website) => {
return shouldDisplayLink(website.id) ? (
<li key={website.id}>
<a href={website.url} className={styles.link}>
{getIcon(website.id)}
<span className="screen-reader-text">{website.name}</span>
</a>
</li>
) : (
''
);
});
return (
<ExpandableWidget title={title} expand={true}>
<ul className={styles.list}>{items}</ul>
</ExpandableWidget>
);
};
export default SocialMedia;
|