mirror of
https://github.com/hazemKrimi/personal-website.git
synced 2026-05-02 02:10:27 +00:00
45 lines
1.1 KiB
TypeScript
45 lines
1.1 KiB
TypeScript
import { FC, useContext } from 'react';
|
|
import { DarkModeContext } from '../../components/DarkMode';
|
|
import { StyledCard } from './styles';
|
|
import Image from 'next/image';
|
|
import Link from 'next/link';
|
|
|
|
interface Props {
|
|
title: string;
|
|
description: string;
|
|
image?: string;
|
|
tags?: string[];
|
|
href: string;
|
|
target?: HTMLAnchorElement['target'];
|
|
onClick?: () => void;
|
|
}
|
|
|
|
const Card: FC<Props> = ({ title, description, image, tags, href, target, onClick }) => {
|
|
const { dark } = useContext(DarkModeContext);
|
|
|
|
return (
|
|
<Link href={href} passHref>
|
|
<StyledCard as='a' target={target} dark={dark} onClick={onClick} image={!!image}>
|
|
<div>
|
|
<h3>{title}</h3>
|
|
<p>{description}</p>
|
|
{tags && (
|
|
<div className='tags-wrapper'>
|
|
{tags.map((tag, index) => (
|
|
<span key={index}>#{tag} </span>
|
|
))}
|
|
</div>
|
|
)}
|
|
</div>
|
|
{image ? (
|
|
<Image src={image} width='100%' height='100%' layout='responsive' />
|
|
) : (
|
|
<Image src='/no-image.png' width='100%' height='100%' layout='responsive' />
|
|
)}
|
|
</StyledCard>
|
|
</Link>
|
|
);
|
|
};
|
|
|
|
export default Card;
|