stacker.news/pages/top/[[...within]].js

76 lines
2.4 KiB
JavaScript
Raw Normal View History

2021-10-21 22:05:06 +00:00
import Layout from '../../components/layout'
import Items from '../../components/items'
import { useRouter } from 'next/router'
2021-10-26 20:49:37 +00:00
import { getGetServerSideProps } from '../../api/ssrApollo'
2021-10-21 22:05:06 +00:00
import { MORE_ITEMS } from '../../fragments/items'
2021-11-09 22:43:56 +00:00
import { Nav, Navbar } from 'react-bootstrap'
2021-10-21 22:05:06 +00:00
import styles from '../../components/header.module.css'
import Link from 'next/link'
2021-10-26 20:49:37 +00:00
export const getServerSideProps = getGetServerSideProps(MORE_ITEMS, { sort: 'top'})
2021-10-21 22:05:06 +00:00
2021-10-26 20:49:37 +00:00
export default function Index ({ data: { moreItems: { items, cursor } } }) {
2021-10-21 22:05:06 +00:00
const router = useRouter()
const path = router.asPath.split('?')[0]
return (
<Layout>
2021-11-12 22:39:52 +00:00
<Navbar className='pt-0'>
2021-10-21 22:05:06 +00:00
<Nav
className={styles.navbarNav}
activeKey={path}
>
<Nav.Item>
<Link href='/top/day' passHref>
<Nav.Link
className={styles.navLink}
onClick={() => localStorage.setItem('topWithin', 'day')}>
day
</Nav.Link>
</Link>
</Nav.Item>
<Nav.Item>
<Link href='/top/week' passHref>
<Nav.Link
className={styles.navLink}
onClick={() => localStorage.setItem('topWithin', 'week')}>
week
</Nav.Link>
</Link>
</Nav.Item>
<Nav.Item>
<Link href='/top/month' passHref>
<Nav.Link
className={styles.navLink}
onClick={() => localStorage.setItem('topWithin', 'month')}>
month
</Nav.Link>
</Link>
</Nav.Item>
<Nav.Item>
<Link href='/top/year' passHref>
<Nav.Link
className={styles.navLink}
onClick={() => localStorage.setItem('topWithin', 'year')}>
year
</Nav.Link>
</Link>
</Nav.Item>
<Nav.Item>
<Link href='/top' passHref>
<Nav.Link
className={styles.navLink}
onClick={() => localStorage.removeItem('topWithin')}>
forever
</Nav.Link>
</Link>
</Nav.Item>
</Nav>
2021-11-09 22:43:56 +00:00
</Navbar>
2021-10-21 22:05:06 +00:00
<Items
items={items} cursor={cursor}
2021-10-26 20:49:37 +00:00
variables={{ sort: 'top', within: router.query?.within }} rank
2021-10-21 22:05:06 +00:00
/>
</Layout>
)
}