2021-12-21 15:29:42 -06:00
|
|
|
import { gql, useApolloClient, useLazyQuery, useQuery } from '@apollo/client'
|
|
|
|
import { useEffect, useState } from 'react'
|
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'
|
|
|
|
import { Nav, Navbar } from 'react-bootstrap'
|
|
|
|
import { COMMENTS_QUERY } from '../fragments/items'
|
|
|
|
import { COMMENTS } from '../fragments/comments'
|
2021-04-15 14:41:02 -05:00
|
|
|
|
2021-12-21 15:29:42 -06:00
|
|
|
export function CommentsHeader ({ handleSort }) {
|
|
|
|
const [sort, setSort] = useState('hot')
|
|
|
|
|
|
|
|
const getHandleClick = sort => {
|
|
|
|
return () => {
|
|
|
|
setSort(sort)
|
|
|
|
handleSort(sort)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2022-01-07 12:55:40 -06:00
|
|
|
<Navbar className='py-1'>
|
2021-12-21 15:29:42 -06:00
|
|
|
<Nav
|
|
|
|
className={styles.navbarNav}
|
|
|
|
activeKey={sort}
|
|
|
|
>
|
|
|
|
<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>
|
|
|
|
</Nav>
|
|
|
|
</Navbar>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function Comments ({ parentId, comments, ...props }) {
|
|
|
|
const client = useApolloClient()
|
2021-06-24 18:56:01 -05:00
|
|
|
useEffect(() => {
|
|
|
|
const hash = window.location.hash
|
|
|
|
if (hash) {
|
|
|
|
document.querySelector(hash).scrollIntoView({ behavior: 'smooth' })
|
|
|
|
}
|
|
|
|
}, [])
|
2021-12-21 15:29:42 -06:00
|
|
|
const [getComments, { loading }] = useLazyQuery(COMMENTS_QUERY, {
|
|
|
|
fetchPolicy: 'network-only',
|
|
|
|
onCompleted: data => {
|
|
|
|
client.writeFragment({
|
|
|
|
id: `Item:${parentId}`,
|
|
|
|
fragment: gql`
|
|
|
|
${COMMENTS}
|
|
|
|
fragment Comments on Item {
|
|
|
|
comments {
|
|
|
|
...CommentsRecursive
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`,
|
|
|
|
fragmentName: 'Comments',
|
|
|
|
data: {
|
|
|
|
comments: data.comments
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
})
|
2021-06-24 18:56:01 -05:00
|
|
|
|
2021-12-21 15:29:42 -06:00
|
|
|
return (
|
|
|
|
<>
|
|
|
|
{comments.length ? <CommentsHeader handleSort={sort => getComments({ variables: { id: parentId, sort } })} /> : null}
|
|
|
|
{loading
|
|
|
|
? <CommentsSkeleton />
|
|
|
|
: comments.map(item => (
|
|
|
|
<Comment key={item.id} item={item} {...props} />
|
|
|
|
))}
|
|
|
|
</>
|
|
|
|
)
|
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
|
|
|
}
|
|
|
|
|
|
|
|
export function CommentsQuery ({ query, ...props }) {
|
2021-10-26 15:49:37 -05:00
|
|
|
const { error, data } = useQuery(query)
|
2021-04-17 13:15:18 -05:00
|
|
|
|
2021-04-22 17:14:32 -05:00
|
|
|
if (error) return <div>Failed to load!</div>
|
2021-09-06 17:36:08 -05:00
|
|
|
if (!data) {
|
2021-04-26 19:55:48 -05:00
|
|
|
return <CommentsSkeleton />
|
2021-04-22 17:14:32 -05:00
|
|
|
}
|
2021-04-15 14:41:02 -05:00
|
|
|
|
2021-04-26 19:55:48 -05:00
|
|
|
return <Comments comments={data.comments} {...props} />
|
2021-04-15 14:41:02 -05:00
|
|
|
}
|