import React, { useState, useEffect, ReactElement } from 'react' import { useRouter } from 'next/router' import Page from '@shared/Page' import Alert from '@shared/atoms/Alert' import Loader from '@shared/atoms/Loader' import { useAsset } from '@context/Asset' import AssetContent from './AssetContent' export default function AssetDetails({ uri }: { uri: string }): ReactElement { const router = useRouter() const { asset, title, error, isInPurgatory, loading } = useAsset() const [pageTitle, setPageTitle] = useState() useEffect(() => { if (!asset || error) { setPageTitle(title || 'Could not retrieve asset') return } setPageTitle(isInPurgatory ? '' : title) }, [asset, error, isInPurgatory, router, title, uri]) return asset && pageTitle !== undefined && !loading ? ( ) : error ? ( ) : ( ) }