stacker.news/components/comments.js

93 lines
2.6 KiB
JavaScript
Raw Normal View History

2021-04-22 17:14:32 -05:00
import Comment, { CommentSkeleton } from './comment'
2021-12-21 15:29:42 -06:00
import styles from './header.module.css'
2023-07-24 13:35:05 -05:00
import Nav from 'react-bootstrap/Nav'
import Navbar from 'react-bootstrap/Navbar'
import { numWithUnits } from '../lib/format'
import { defaultCommentSort } from '../lib/item'
2023-07-25 19:45:35 -05:00
import { useRouter } from 'next/router'
2021-04-15 14:41:02 -05:00
export function CommentsHeader ({ handleSort, pinned, bio, parentCreatedAt, commentSats }) {
2023-07-25 19:45:35 -05:00
const router = useRouter()
const sort = router.query.sort || defaultCommentSort(pinned, bio, parentCreatedAt)
2021-12-21 15:29:42 -06:00
const getHandleClick = sort => {
return () => {
handleSort(sort)
}
}
return (
2023-07-24 13:35:05 -05:00
<Navbar className='pt-1 pb-0 px-3'>
2021-12-21 15:29:42 -06:00
<Nav
className={styles.navbarNav}
activeKey={sort}
>
2022-09-01 16:06:11 -05:00
<Nav.Item className='text-muted'>
{numWithUnits(commentSats)}
2021-12-21 15:29:42 -06:00
</Nav.Item>
2023-07-24 13:35:05 -05:00
<div className='ms-auto d-flex'>
2022-09-01 16:06:11 -05:00
<Nav.Item>
<Nav.Link
eventKey='hot'
className={styles.navLink}
onClick={getHandleClick('hot')}
>
hot
</Nav.Link>
</Nav.Item>
<Nav.Item>
<Nav.Link
eventKey='recent'
className={styles.navLink}
onClick={getHandleClick('recent')}
>
recent
</Nav.Link>
</Nav.Item>
<Nav.Item>
<Nav.Link
eventKey='top'
className={styles.navLink}
onClick={getHandleClick('top')}
>
top
</Nav.Link>
</Nav.Item>
</div>
2021-12-21 15:29:42 -06:00
</Nav>
</Navbar>
)
}
export default function Comments ({ parentId, pinned, bio, parentCreatedAt, commentSats, comments, ...props }) {
2023-07-25 19:45:35 -05:00
const router = useRouter()
2021-06-24 18:56:01 -05:00
2021-12-21 15:29:42 -06:00
return (
<>
2023-07-25 19:45:35 -05:00
{comments?.length > 0
? <CommentsHeader
commentSats={commentSats} parentCreatedAt={parentCreatedAt}
pinned={pinned} bio={bio} handleSort={sort => {
2023-10-26 14:36:20 -05:00
const { commentsViewedAt, commentId, ...query } = router.query
2023-07-25 19:45:35 -05:00
delete query.nodata
router.push({
pathname: router.pathname,
2023-10-26 14:36:20 -05:00
query: { ...query, commentsViewedAt, sort }
}, {
pathname: `/items/${parentId}`,
query: sort === defaultCommentSort(pinned, bio, parentCreatedAt) ? undefined : { sort }
}, { scroll: false })
}}
/>
: null}
2023-07-25 19:45:35 -05:00
{comments.map(item => (
<Comment depth={1} key={item.id} item={item} {...props} />
))}
2021-12-21 15:29:42 -06:00
</>
)
2021-04-26 19:55:48 -05:00
}
export function CommentsSkeleton () {
2021-05-05 13:13:14 -05:00
return <CommentSkeleton skeletonChildren={7} />
2021-04-26 19:55:48 -05:00
}