-
Notifications
You must be signed in to change notification settings - Fork 401
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
2e42e9e
commit 61f1ee0
Showing
8 changed files
with
294 additions
and
116 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,120 @@ | ||
import { useRouter } from 'next/router'; | ||
import { getStaticPropsRevalidate } from 'next-swr'; | ||
|
||
import { ContentList, DefaultLayout, UserHeader } from '@/TabNewsUI'; | ||
import { FaUser } from '@/TabNewsUI/icons'; | ||
import { NotFoundError } from 'errors'; | ||
import authorization from 'models/authorization.js'; | ||
import content from 'models/content.js'; | ||
import user from 'models/user.js'; | ||
import validator from 'models/validator.js'; | ||
import { useUser } from 'pages/interface'; | ||
|
||
export default function RootContent({ contentListFound, pagination, username }) { | ||
const { push } = useRouter(); | ||
const { user, isLoading } = useUser(); | ||
const isAuthenticatedUser = user && user.username === username; | ||
|
||
return ( | ||
<DefaultLayout metadata={{ title: `Publicações · Página ${pagination.currentPage} · ${username}` }}> | ||
<UserHeader username={username} rootContentCount={pagination.totalRows} /> | ||
|
||
<ContentList | ||
contentList={contentListFound} | ||
pagination={pagination} | ||
paginationBasePath={`/${username}/conteudos`} | ||
emptyStateProps={{ | ||
isLoading: isLoading, | ||
title: 'Nenhuma publicação encontrada', | ||
description: `${isAuthenticatedUser ? 'Você' : username} ainda não fez nenhuma publicação.`, | ||
icon: FaUser, | ||
action: isAuthenticatedUser && { | ||
text: 'Publicar conteúdo', | ||
onClick: () => push('/publicar'), | ||
}, | ||
}} | ||
/> | ||
</DefaultLayout> | ||
); | ||
} | ||
|
||
export async function getStaticPaths() { | ||
return { | ||
paths: [], | ||
fallback: 'blocking', | ||
}; | ||
} | ||
|
||
export const getStaticProps = getStaticPropsRevalidate(async (context) => { | ||
const userTryingToGet = user.createAnonymous(); | ||
|
||
try { | ||
context.params = validator(context.params, { | ||
username: 'required', | ||
page: 'optional', | ||
per_page: 'optional', | ||
}); | ||
} catch (error) { | ||
return { | ||
notFound: true, | ||
}; | ||
} | ||
|
||
let results; | ||
let secureUserFound; | ||
|
||
try { | ||
const userFound = await user.findOneByUsername(context.params.username); | ||
|
||
secureUserFound = authorization.filterOutput(userTryingToGet, 'read:user', userFound); | ||
|
||
results = await content.findWithStrategy({ | ||
strategy: 'new', | ||
where: { | ||
parent_id: null, | ||
owner_id: secureUserFound.id, | ||
status: 'published', | ||
}, | ||
attributes: { | ||
exclude: ['body'], | ||
}, | ||
page: context.params.page, | ||
per_page: context.params.per_page, | ||
}); | ||
} catch (error) { | ||
if (error instanceof NotFoundError) { | ||
return { | ||
notFound: true, | ||
revalidate: 1, | ||
}; | ||
} | ||
|
||
throw error; | ||
} | ||
|
||
const contentListFound = results.rows; | ||
|
||
const secureContentListFound = authorization.filterOutput(userTryingToGet, 'read:content:list', contentListFound); | ||
|
||
if (secureContentListFound.length === 0 && context.params.page !== 1) { | ||
const lastValidPage = `/${secureUserFound.username}/conteudos/${results.pagination.lastPage || 1}`; | ||
const revalidate = context.params.page > results.pagination.lastPage + 1 ? 60 : 1; | ||
|
||
return { | ||
redirect: { | ||
destination: lastValidPage, | ||
}, | ||
revalidate, | ||
}; | ||
} | ||
|
||
return { | ||
props: { | ||
contentListFound: secureContentListFound, | ||
pagination: results.pagination, | ||
username: secureUserFound.username, | ||
}, | ||
|
||
revalidate: 10, | ||
}; | ||
}); |
Oops, something went wrong.