From 62afb57ff3e7b6516b0d3d39c88ed29a1468bd3a Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Mon, 10 Jan 2022 15:19:27 +0100 Subject: chore: add a social media widget on contact and cv pages --- src/components/Widget/SocialMedia/SocialMedia.tsx | 72 +++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 src/components/Widget/SocialMedia/SocialMedia.tsx (limited to 'src/components/Widget/SocialMedia/SocialMedia.tsx') diff --git a/src/components/Widget/SocialMedia/SocialMedia.tsx b/src/components/Widget/SocialMedia/SocialMedia.tsx new file mode 100644 index 0000000..9ca0627 --- /dev/null +++ b/src/components/Widget/SocialMedia/SocialMedia.tsx @@ -0,0 +1,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'; + +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 ; + case 'gitlab': + return ; + case 'linkedin': + return ; + case 'twitter': + return ; + 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) ? ( +
  • + + {getIcon(website.id)} + {website.name} + +
  • + ) : ( + '' + ); + }); + + return ( +
    +

    {title}

    +
      {items}
    +
    + ); +}; + +export default SocialMedia; -- cgit v1.2.3