mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-14 07:26:52 +00:00
68 lines
2.1 KiB
JavaScript
68 lines
2.1 KiB
JavaScript
import { siteConfig } from '@/lib/config'
|
|
import { useGlobal } from '@/lib/global'
|
|
import { RecentComments } from '@waline/client'
|
|
import Link from 'next/link'
|
|
import { useEffect, useState } from 'react'
|
|
|
|
/**
|
|
* @see https://waline.js.org/guide/get-started.html
|
|
* @param {*} props
|
|
* @returns
|
|
*/
|
|
const HexoRecentComments = props => {
|
|
const [comments, updateComments] = useState([])
|
|
const { locale } = useGlobal()
|
|
const [onLoading, changeLoading] = useState(true)
|
|
useEffect(() => {
|
|
RecentComments({
|
|
serverURL: siteConfig('COMMENT_WALINE_SERVER_URL'),
|
|
count: 5
|
|
}).then(({ comments }) => {
|
|
changeLoading(false)
|
|
updateComments(comments)
|
|
})
|
|
}, [])
|
|
|
|
return (
|
|
<section className='card shadow-md hover:shadow-md dark:text-gray-300 border dark:border-black rounded-xl lg:p-6 p-4 bg-white dark:bg-hexo-black-gray lg:duration-100'>
|
|
<div className=' mb-2 px-1 justify-between'>
|
|
<i className='mr-2 fas fas fa-comment' />
|
|
{locale.COMMON.RECENT_COMMENTS}
|
|
</div>
|
|
|
|
{onLoading && (
|
|
<div>
|
|
Loading...
|
|
<i className='ml-2 fas fa-spinner animate-spin' />
|
|
</div>
|
|
)}
|
|
{!onLoading && comments && comments.length === 0 && (
|
|
<div>No Comments</div>
|
|
)}
|
|
{!onLoading &&
|
|
comments &&
|
|
comments.length > 0 &&
|
|
comments.map(comment => (
|
|
<div key={comment.objectId} className='pb-2 pl-1'>
|
|
<div
|
|
className='dark:text-gray-200 text-sm waline-recent-content wl-content'
|
|
dangerouslySetInnerHTML={{ __html: comment.comment }}
|
|
/>
|
|
<div className='dark:text-gray-400 text-gray-400 text-sm text-right cursor-pointer hover:text-red-500 hover:underline pt-1 pr-2'>
|
|
<Link
|
|
href={{
|
|
pathname: comment.url,
|
|
hash: comment.objectId,
|
|
query: { target: 'comment' }
|
|
}}>
|
|
--{comment.nick}
|
|
</Link>
|
|
</div>
|
|
</div>
|
|
))}
|
|
</section>
|
|
)
|
|
}
|
|
|
|
export default HexoRecentComments
|