mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-13 23:16:47 +00:00
63 lines
2.3 KiB
JavaScript
63 lines
2.3 KiB
JavaScript
import LazyImage from '@/components/LazyImage'
|
|
import NotionIcon from '@/components/NotionIcon'
|
|
import { siteConfig } from '@/lib/config'
|
|
import Link from 'next/link'
|
|
import TagItemMini from './TagItemMini'
|
|
|
|
const BlogPostCard = ({ index, post, showSummary, siteInfo }) => {
|
|
// 主题默认强制显示图片
|
|
if (post && !post.pageCoverThumbnail) {
|
|
post.pageCoverThumbnail =
|
|
siteInfo?.pageCover || siteConfig('RANDOM_IMAGE_URL')
|
|
}
|
|
|
|
return (
|
|
<article
|
|
data-wow-delay='.2s'
|
|
className='wow fadeInUp w-full mb-4 cursor-pointer overflow-hidden shadow-movie dark:bg-hexo-black-gray'>
|
|
<Link href={post?.href} passHref legacyBehavior>
|
|
{/* 固定高度 ,空白用图片拉升填充 */}
|
|
<div className='group flex flex-col aspect-[2/3] justify-between relative'>
|
|
{/* 图片 填充卡片 */}
|
|
<div className='flex flex-grow w-full h-full relative duration-200 cursor-pointer transform overflow-hidden'>
|
|
<LazyImage
|
|
src={post?.pageCoverThumbnail}
|
|
alt={post.title}
|
|
className='h-full w-full group-hover:brightness-90 group-hover:scale-105 transform object-cover duration-500'
|
|
/>
|
|
</div>
|
|
|
|
<div className='absolute bottom-28 z-20'>
|
|
{post?.tagItems && post?.tagItems.length > 0 && (
|
|
<>
|
|
<div className='px-6 justify-between flex p-2'>
|
|
{post.tagItems.map(tag => (
|
|
<TagItemMini key={tag.name} tag={tag} />
|
|
))}
|
|
</div>
|
|
</>
|
|
)}
|
|
</div>
|
|
{/* 阴影遮罩 */}
|
|
<h2 className='absolute bottom-10 px-6 transition-all duration-200 text-white text-2xl font-semibold break-words shadow-text z-20'>
|
|
{siteConfig('POST_TITLE_ICON') && (
|
|
<NotionIcon icon={post.pageIcon} />
|
|
)}
|
|
{post.title}
|
|
</h2>
|
|
|
|
<p className='absolute bottom-3 z-20 line-clamp-1 text-xs mx-6'>
|
|
{post?.summary}
|
|
</p>
|
|
|
|
<div className='h-3/4 w-full absolute left-0 bottom-0 z-10'>
|
|
<div className='h-full w-full absolute opacity-80 group-hover:opacity-100 transition-all duration-1000 bg-gradient-to-b from-transparent to-black'></div>
|
|
</div>
|
|
</div>
|
|
</Link>
|
|
</article>
|
|
)
|
|
}
|
|
|
|
export default BlogPostCard
|