aboutsummaryrefslogtreecommitdiffstats
path: root/src/pages/blog
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2023-12-19 17:11:48 +0100
committerArmand Philippot <git@armandphilippot.com>2023-12-19 17:11:48 +0100
commit67ac79f8ba2ea900ec0ac67e56387889ee887a48 (patch)
treefad602f33265f1c2186883ef581973caf517a0aa /src/pages/blog
parentfc77c0a7e9c81f5bc1a69dee945ce71b9511b3cc (diff)
fix(layout): refine pagination when JS is disabled
* fix the total number of pages * hide the load more button and the progress bar * remove the informative notice since it is no longer necessary * if the page number is equal to 1, use Blog route directly (NextJS is not able to redirect the user when JS is disabled)
Diffstat (limited to 'src/pages/blog')
-rw-r--r--src/pages/blog/index.tsx21
-rw-r--r--src/pages/blog/page/[number].tsx33
2 files changed, 19 insertions, 35 deletions
diff --git a/src/pages/blog/index.tsx b/src/pages/blog/index.tsx
index f58d36f..0451bd7 100644
--- a/src/pages/blog/index.tsx
+++ b/src/pages/blog/index.tsx
@@ -55,8 +55,11 @@ import {
useTopicsList,
} from '../../utils/hooks';
-const renderPaginationLink: RenderPaginationLink = (pageNum) =>
- `${ROUTES.BLOG}${PAGINATED_ROUTE_PREFIX}/${pageNum}`;
+const renderPaginationLink: RenderPaginationLink = (pageNum) => {
+ if (pageNum === 1) return ROUTES.BLOG;
+
+ return `${ROUTES.BLOG}${PAGINATED_ROUTE_PREFIX}/${pageNum}`;
+};
type BlogPageProps = {
data: {
@@ -113,12 +116,6 @@ const BlogPage: NextPageWithLayout<BlogPageProps> = ({ data }) => {
id: '7TbbIk',
}),
pagination: {
- noJS: intl.formatMessage({
- defaultMessage:
- "You can't load more articles without Javascript, please use the pagination instead.",
- description: 'BlogPage: pagination no script message',
- id: 'ZMES/E',
- }),
title: intl.formatMessage({
defaultMessage: 'Pagination',
description: 'BlogPage: pagination accessible name',
@@ -276,12 +273,6 @@ const BlogPage: NextPageWithLayout<BlogPageProps> = ({ data }) => {
</Notice>
) : null}
<noscript>
- <Notice
- // eslint-disable-next-line react/jsx-no-literals
- kind="info"
- >
- {messages.pagination.noJS}
- </Notice>
<Pagination
aria-label={messages.pagination.title}
className={styles.pagination}
@@ -289,7 +280,7 @@ const BlogPage: NextPageWithLayout<BlogPageProps> = ({ data }) => {
isCentered
renderItemAriaLabel={renderPaginationLabel}
renderLink={renderPaginationLink}
- total={data.posts.pageInfo.total}
+ total={Math.ceil(data.posts.pageInfo.total / CONFIG.postsPerPage)}
/>
</noscript>
</PageBody>
diff --git a/src/pages/blog/page/[number].tsx b/src/pages/blog/page/[number].tsx
index e524a64..d06e663 100644
--- a/src/pages/blog/page/[number].tsx
+++ b/src/pages/blog/page/[number].tsx
@@ -64,14 +64,18 @@ import {
useTopicsList,
} from '../../../utils/hooks';
-const renderPaginationLink: RenderPaginationLink = (pageNum) =>
- `${ROUTES.BLOG}${PAGINATED_ROUTE_PREFIX}/${pageNum}`;
+const renderPaginationLink: RenderPaginationLink = (pageNum) => {
+ if (pageNum === 1) return ROUTES.BLOG;
+
+ return `${ROUTES.BLOG}${PAGINATED_ROUTE_PREFIX}/${pageNum}`;
+};
type BlogPageProps = {
data: {
posts: GraphQLConnection<WPPostPreview>;
thematics: GraphQLConnection<WPThematicPreview>;
topics: GraphQLConnection<WPTopicPreview>;
+ totalPosts: number;
};
lastCursor: Maybe<Nullable<string>>;
pageNumber: number;
@@ -131,12 +135,6 @@ const Blog: FC<Pick<BlogPageProps, 'data' | 'lastCursor' | 'pageNumber'>> = ({
}
),
pagination: {
- noJS: intl.formatMessage({
- defaultMessage:
- "You can't load more articles without Javascript, please use the pagination instead.",
- description: 'BlogPage: pagination no script message',
- id: 'ZMES/E',
- }),
title: intl.formatMessage({
defaultMessage: 'Pagination',
description: 'BlogPage: pagination accessible name',
@@ -266,7 +264,7 @@ const Blog: FC<Pick<BlogPageProps, 'data' | 'lastCursor' | 'pageNumber'>> = ({
</Head>
<PageHeader
heading={messages.pageTitle}
- meta={{ total: data.posts.pageInfo.total }}
+ meta={{ total: data.totalPosts }}
/>
<PageBody>
{articles ? (
@@ -295,12 +293,6 @@ const Blog: FC<Pick<BlogPageProps, 'data' | 'lastCursor' | 'pageNumber'>> = ({
</Notice>
) : null}
<noscript>
- <Notice
- // eslint-disable-next-line react/jsx-no-literals
- kind="info"
- >
- {messages.pagination.noJS}
- </Notice>
<Pagination
aria-label={messages.pagination.title}
className={styles.pagination}
@@ -308,7 +300,7 @@ const Blog: FC<Pick<BlogPageProps, 'data' | 'lastCursor' | 'pageNumber'>> = ({
isCentered
renderItemAriaLabel={renderPaginationLabel}
renderLink={renderPaginationLink}
- total={data.posts.pageInfo.total}
+ total={Math.ceil(data.totalPosts / CONFIG.postsPerPage)}
/>
</noscript>
</PageBody>
@@ -390,10 +382,10 @@ export const getStaticProps: GetStaticProps<BlogPageProps> = async ({
},
};
- const lastCursor =
- pageNumber > 1
- ? await fetchLastPostCursor(CONFIG.postsPerPage * (pageNumber - 1))
- : null;
+ const lastCursor = await fetchLastPostCursor(
+ CONFIG.postsPerPage * (pageNumber - 1)
+ );
+ const totalPosts = await fetchPostsCount();
const posts = await fetchPostsList({
first: CONFIG.postsPerPage,
after: lastCursor,
@@ -410,6 +402,7 @@ export const getStaticProps: GetStaticProps<BlogPageProps> = async ({
posts: JSON.parse(JSON.stringify(posts)),
thematics,
topics,
+ totalPosts,
},
lastCursor,
pageNumber,