mirror of
https://github.com/hazemKrimi/personal-website.git
synced 2026-05-01 18:00:26 +00:00
39 lines
851 B
TypeScript
39 lines
851 B
TypeScript
import { FC } from 'react';
|
|
import { StyledCard } from './styles';
|
|
import Image from 'next/image';
|
|
|
|
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 }) => {
|
|
return (
|
|
<StyledCard href={href} onClick={onClick} image={!!image} target={target}>
|
|
<div className='card-content'>
|
|
<h3>{title}</h3>
|
|
<p>{description}</p>
|
|
{tags && (
|
|
<div className='tags-wrapper'>
|
|
{tags.map((tag, index) => (
|
|
<span key={index}>#{tag} </span>
|
|
))}
|
|
</div>
|
|
)}
|
|
</div>
|
|
{image && (
|
|
<div className='card-image'>
|
|
<Image alt={title} src={image} fill />
|
|
</div>
|
|
)}
|
|
</StyledCard>
|
|
);
|
|
};
|
|
|
|
export default Card;
|