blob: 351fd4896c0bb3b651641dabc0b06fc7c2960959 (
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
|
import { socialWebsites } from '@config/social-media';
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';
const SocialMedia = ({
title,
github = false,
gitlab = false,
linkedin = false,
twitter = false,
}: {
title: string;
github?: boolean;
gitlab?: boolean;
linkedin?: boolean;
twitter?: boolean;
}) => {
const getIcon = (id: string) => {
switch (id) {
case 'github':
return <GithubIcon />;
case 'gitlab':
return <GitlabIcon />;
case 'linkedin':
return <LinkedInIcon />;
case 'twitter':
return <TwitterIcon />;
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 = socialWebsites.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;
|