2024-03-20 01:37:31 +01:00
|
|
|
import Layout from '@/components/layout'
|
|
|
|
import { ITEM_FULL } from '@/fragments/items'
|
|
|
|
import ItemFull from '@/components/item-full'
|
|
|
|
import { getGetServerSideProps } from '@/api/ssrApollo'
|
2021-09-30 10:46:58 -05:00
|
|
|
import { useQuery } from '@apollo/client'
|
2023-07-23 10:08:43 -05:00
|
|
|
import { useRouter } from 'next/router'
|
2024-03-20 01:37:31 +01:00
|
|
|
import PageLoading from '@/components/page-loading'
|
2021-09-30 10:46:58 -05:00
|
|
|
|
2023-08-28 12:52:15 -05:00
|
|
|
export const getServerSideProps = getGetServerSideProps({
|
|
|
|
query: ITEM_FULL,
|
|
|
|
notFound: data => !data.item || (data.item.status === 'STOPPED' && !data.item.mine)
|
|
|
|
})
|
2021-09-30 10:46:58 -05:00
|
|
|
|
2023-07-23 10:08:43 -05:00
|
|
|
export default function Item ({ ssrData }) {
|
|
|
|
const router = useRouter()
|
2021-09-30 10:46:58 -05:00
|
|
|
|
2023-07-25 19:45:35 -05:00
|
|
|
const { data } = useQuery(ITEM_FULL, { variables: { ...router.query } })
|
2023-07-23 10:08:43 -05:00
|
|
|
if (!data && !ssrData) return <PageLoading />
|
|
|
|
|
|
|
|
const { item } = data || ssrData
|
2023-05-05 12:38:56 -05:00
|
|
|
const sub = item.subName || item.root?.subName
|
2022-02-17 11:23:43 -06:00
|
|
|
|
2021-09-30 10:46:58 -05:00
|
|
|
return (
|
2023-07-23 10:08:43 -05:00
|
|
|
<Layout sub={sub} item={item}>
|
2021-09-30 10:46:58 -05:00
|
|
|
<ItemFull item={item} />
|
|
|
|
</Layout>
|
|
|
|
)
|
|
|
|
}
|