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'
|
2023-08-08 17:04:06 -04:00
|
|
|
import { numWithUnits } from '../lib/format'
|
2023-07-23 10:08:43 -05:00
|
|
|
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
|
|
|
|
2023-07-23 10:08:43 -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'>
|
2023-08-08 17:04:06 -04:00
|
|
|
{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>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2023-07-23 10:08:43 -05:00
|
|
|
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
|
2022-09-06 09:48:37 -05:00
|
|
|
? <CommentsHeader
|
2023-07-23 10:08:43 -05:00
|
|
|
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 })
|
2022-09-06 09:48:37 -05:00
|
|
|
}}
|
|
|
|
/>
|
|
|
|
: 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
|
|
|
}
|