summaryrefslogtreecommitdiffstats
path: root/src/components
diff options
context:
space:
mode:
authorArmand Philippot <git@armandphilippot.com>2022-02-14 17:16:53 +0100
committerArmand Philippot <git@armandphilippot.com>2022-02-14 17:30:37 +0100
commit916c512bf5a31041ac87296e1382f84c9367b955 (patch)
tree9541124a1339ce6e12f46983fce875b41d1fff00 /src/components
parent79f7688703fe42ce87c92567f5bc92b6691eaa20 (diff)
chore: display initial posts, thematics & topics
By fetching the data in getStaticProps, I can display the data even for users with Javascript disabled.
Diffstat (limited to 'src/components')
-rw-r--r--src/components/Widgets/RelatedThematics/RelatedThematics.tsx7
-rw-r--r--src/components/Widgets/RelatedTopics/RelatedTopics.tsx7
-rw-r--r--src/components/Widgets/ThematicsList/ThematicsList.tsx13
-rw-r--r--src/components/Widgets/TopicsList/TopicsList.tsx13
4 files changed, 14 insertions, 26 deletions
diff --git a/src/components/Widgets/RelatedThematics/RelatedThematics.tsx b/src/components/Widgets/RelatedThematics/RelatedThematics.tsx
index e89d887..74325bb 100644
--- a/src/components/Widgets/RelatedThematics/RelatedThematics.tsx
+++ b/src/components/Widgets/RelatedThematics/RelatedThematics.tsx
@@ -21,6 +21,7 @@ const RelatedThematics = ({ thematics }: { thematics: ThematicPreview[] }) => {
return (
<ExpandableWidget
+ expand={true}
title={intl.formatMessage(
{
defaultMessage:
@@ -31,12 +32,6 @@ const RelatedThematics = ({ thematics }: { thematics: ThematicPreview[] }) => {
)}
withBorders={true}
>
- <noscript>
- {intl.formatMessage({
- defaultMessage: 'Javascript is required to load the thematics.',
- description: 'RelatedThematics: noscript tag',
- })}
- </noscript>
<List items={thematicsList} />
</ExpandableWidget>
);
diff --git a/src/components/Widgets/RelatedTopics/RelatedTopics.tsx b/src/components/Widgets/RelatedTopics/RelatedTopics.tsx
index e225608..1702e82 100644
--- a/src/components/Widgets/RelatedTopics/RelatedTopics.tsx
+++ b/src/components/Widgets/RelatedTopics/RelatedTopics.tsx
@@ -21,6 +21,7 @@ const RelatedTopics = ({ topics }: { topics: TopicPreview[] }) => {
return (
<ExpandableWidget
+ expand={true}
title={intl.formatMessage(
{
defaultMessage:
@@ -31,12 +32,6 @@ const RelatedTopics = ({ topics }: { topics: TopicPreview[] }) => {
)}
withBorders={true}
>
- <noscript>
- {intl.formatMessage({
- defaultMessage: 'Javascript is required to load the topics.',
- description: 'RelatedTopics: noscript tag',
- })}
- </noscript>
<List items={topicsList} />
</ExpandableWidget>
);
diff --git a/src/components/Widgets/ThematicsList/ThematicsList.tsx b/src/components/Widgets/ThematicsList/ThematicsList.tsx
index f175e80..f50a069 100644
--- a/src/components/Widgets/ThematicsList/ThematicsList.tsx
+++ b/src/components/Widgets/ThematicsList/ThematicsList.tsx
@@ -2,6 +2,7 @@ import Spinner from '@components/Spinner/Spinner';
import { ExpandableWidget, List } from '@components/WidgetParts';
import { getAllThematics } from '@services/graphql/queries';
import { TitleLevel } from '@ts/types/app';
+import { ThematicPreview } from '@ts/types/taxonomies';
import Link from 'next/link';
import { useRouter } from 'next/router';
import { useIntl } from 'react-intl';
@@ -10,9 +11,11 @@ import useSWR from 'swr';
const ThematicsList = ({
title,
titleLevel,
+ initialData,
}: {
title: string;
titleLevel?: TitleLevel;
+ initialData?: ThematicPreview[];
}) => {
const intl = useIntl();
const router = useRouter();
@@ -21,7 +24,9 @@ const ThematicsList = ({
? router.asPath.replace('/thematique/', '')
: '';
- const { data, error } = useSWR('/api/thematics', getAllThematics);
+ const { data, error } = useSWR('/api/thematics', getAllThematics, {
+ fallbackData: initialData,
+ });
const getList = () => {
if (error)
@@ -62,12 +67,6 @@ const ThematicsList = ({
withBorders={true}
expand={true}
>
- <noscript>
- {intl.formatMessage({
- defaultMessage: 'Javascript is required to load the thematics.',
- description: 'ThematicsList: noscript tag',
- })}
- </noscript>
{getList()}
</ExpandableWidget>
);
diff --git a/src/components/Widgets/TopicsList/TopicsList.tsx b/src/components/Widgets/TopicsList/TopicsList.tsx
index e79d1a8..55bf5af 100644
--- a/src/components/Widgets/TopicsList/TopicsList.tsx
+++ b/src/components/Widgets/TopicsList/TopicsList.tsx
@@ -2,6 +2,7 @@ import Spinner from '@components/Spinner/Spinner';
import { ExpandableWidget, List } from '@components/WidgetParts';
import { getAllTopics } from '@services/graphql/queries';
import { TitleLevel } from '@ts/types/app';
+import { TopicPreview } from '@ts/types/taxonomies';
import Link from 'next/link';
import { useRouter } from 'next/router';
import { useIntl } from 'react-intl';
@@ -10,9 +11,11 @@ import useSWR from 'swr';
const TopicsList = ({
title,
titleLevel,
+ initialData,
}: {
title: string;
titleLevel?: TitleLevel;
+ initialData?: TopicPreview[];
}) => {
const intl = useIntl();
const router = useRouter();
@@ -21,7 +24,9 @@ const TopicsList = ({
? router.asPath.replace('/sujet/', '')
: '';
- const { data, error } = useSWR('/api/topics', getAllTopics);
+ const { data, error } = useSWR('/api/topics', getAllTopics, {
+ fallbackData: initialData,
+ });
const getList = () => {
if (error)
@@ -62,12 +67,6 @@ const TopicsList = ({
withBorders={true}
expand={true}
>
- <noscript>
- {intl.formatMessage({
- defaultMessage: 'Javascript is required to load the topics.',
- description: 'TopicsList: noscript tag',
- })}
- </noscript>
{getList()}
</ExpandableWidget>
);