28 lines
623 B
JavaScript
28 lines
623 B
JavaScript
import { Image } from 'react-datocms'
|
|
import cn from 'classnames'
|
|
import Link from 'next/link'
|
|
|
|
export default function CoverImage({ title, responsiveImage, slug }) {
|
|
const image = (
|
|
<Image
|
|
data={{
|
|
...responsiveImage,
|
|
alt: `Cover Image for ${title}`,
|
|
}}
|
|
className={cn('shadow-small', {
|
|
'hover:shadow-medium transition-shadow duration-200': slug,
|
|
})}
|
|
/>
|
|
)
|
|
return (
|
|
<div className="sm:mx-0">
|
|
{slug ? (
|
|
<Link href={`/posts/${slug}`}>
|
|
<a aria-label={title}>{image}</a>
|
|
</Link>
|
|
) : (
|
|
image
|
|
)}
|
|
</div>
|
|
)
|
|
}
|