mirror of
https://github.com/d0zingcat/NotionNext.git
synced 2026-05-14 07:26:52 +00:00
Example主题调整,规范组件命名
This commit is contained in:
62
themes/example/components/RecentCommentListForExample.js
Normal file
62
themes/example/components/RecentCommentListForExample.js
Normal file
@@ -0,0 +1,62 @@
|
||||
import { siteConfig } from '@/lib/config'
|
||||
import { RecentComments } from '@waline/client'
|
||||
import Link from 'next/link'
|
||||
import { useEffect, useState } from 'react'
|
||||
|
||||
/**
|
||||
* 最近评论列表
|
||||
* 基于Waline实现
|
||||
* @see https://waline.js.org/guide/get-started.html
|
||||
* @param {*} props
|
||||
* @returns
|
||||
*/
|
||||
const RecentCommentListForExample = props => {
|
||||
const [comments, updateComments] = useState([])
|
||||
const [onLoading, changeLoading] = useState(true)
|
||||
useEffect(() => {
|
||||
RecentComments({
|
||||
serverURL: siteConfig('COMMENT_WALINE_SERVER_URL'),
|
||||
count: 5
|
||||
}).then(({ comments }) => {
|
||||
changeLoading(false)
|
||||
updateComments(comments)
|
||||
})
|
||||
}, [])
|
||||
|
||||
return (
|
||||
<>
|
||||
{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'>
|
||||
<div
|
||||
className='dark:text-gray-300 text-gray-600 text-xs 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'>
|
||||
<Link
|
||||
href={{
|
||||
pathname: comment.url,
|
||||
hash: comment.objectId,
|
||||
query: { target: 'comment' }
|
||||
}}>
|
||||
--{comment.nick}
|
||||
</Link>
|
||||
</div>
|
||||
</div>
|
||||
))}
|
||||
</>
|
||||
)
|
||||
}
|
||||
|
||||
export default RecentCommentListForExample
|
||||
Reference in New Issue
Block a user