mirror of
https://github.com/r-freeman/portfolio.git
synced 2024-11-22 19:55:42 +00:00
29 lines
690 B
TypeScript
29 lines
690 B
TypeScript
import Link from 'next/link'
|
|
import {ElementType} from 'react'
|
|
import {twMerge} from 'tailwind-merge'
|
|
|
|
type SocialLink = {
|
|
href: string
|
|
ariaLabel: string
|
|
icon: ElementType
|
|
className?: string
|
|
}
|
|
|
|
export function SocialLink({icon: Icon, href, ariaLabel, className}: SocialLink) {
|
|
const iconStyles = twMerge(`
|
|
w-6 h-6
|
|
fill-zinc-500
|
|
transition
|
|
group-hover:fill-zinc-600
|
|
dark:fill-zinc-400
|
|
dark:group-hover:fill-zinc-300
|
|
${className ?? ""}
|
|
`)
|
|
|
|
return (
|
|
<Link className="group -m-1 p-1" href={href} aria-label={ariaLabel}>
|
|
<Icon
|
|
className={iconStyles}/>
|
|
</Link>
|
|
)
|
|
} |