From 06a97bd4f921f745a4bd050c377592bc1eda9e4b Mon Sep 17 00:00:00 2001 From: barbara-chaves Date: Fri, 26 Jul 2024 17:53:07 +0200 Subject: [PATCH 01/11] Fix home styles --- client/src/app/(landing)/globe/page.tsx | 4 +- .../src/app/(landing)/stories/[id]/page.tsx | 26 ------ client/src/components/map/constants.ts | 9 ++ client/src/components/map/legend/index.tsx | 12 +-- .../map/legend/item-types/basic/index.tsx | 2 +- .../legend/item-types/choropleth/index.tsx | 2 +- .../map/legend/item-types/gradient/index.tsx | 2 +- .../map/legend/item-types/header.tsx | 2 +- .../map/legend/item-types/matrix/index.tsx | 2 +- .../map/legend/item-types/switch/index.tsx | 2 +- .../map/legend/item-types/timeline/index.tsx | 2 +- client/src/components/ui/button.tsx | 2 +- client/src/components/ui/card.tsx | 7 +- client/src/components/ui/checkbox-button.tsx | 6 +- client/src/components/ui/dialog.tsx | 10 +-- .../src/containers/globe/categories/item.tsx | 2 +- .../containers/globe/dashboard/numbers.tsx | 4 +- .../containers/globe/dashboard/regions.tsx | 4 +- client/src/containers/globe/filters/index.tsx | 30 +++++-- client/src/containers/globe/filters/item.tsx | 15 ++-- client/src/containers/globe/index.tsx | 45 ++++++++-- client/src/containers/globe/search/index.tsx | 11 ++- .../containers/globe/top-stories/index.tsx | 2 +- .../src/containers/globe/top-stories/item.tsx | 20 ++--- client/src/containers/map/index.tsx | 10 +-- .../map/markers/globe-markers/index.tsx | 51 ++++++----- client/src/containers/story/header.tsx | 90 +++++++++++++++++-- client/src/containers/story/index.tsx | 1 + client/src/containers/story/steps/index.tsx | 4 +- .../steps/layouts/components/map-content.tsx | 2 +- .../story/steps/layouts/outro-step.tsx | 2 +- client/src/hooks/stories/useStories.ts | 16 ++++ client/src/lib/stories/index.ts | 14 ++- client/src/styles/globals.css | 5 +- yarn.lock | 6 +- 35 files changed, 277 insertions(+), 147 deletions(-) create mode 100644 client/src/hooks/stories/useStories.ts diff --git a/client/src/app/(landing)/globe/page.tsx b/client/src/app/(landing)/globe/page.tsx index e9b5aa0..f4dd71a 100644 --- a/client/src/app/(landing)/globe/page.tsx +++ b/client/src/app/(landing)/globe/page.tsx @@ -35,7 +35,7 @@ async function prefetchQueries(searchParams: HomePageProps['searchParams']) { }); // Stories - let categoryId; + let categoryId: string | undefined; // If there is a category in the search params, we need to get the category id to use as a category filter if (searchParams.category) { @@ -43,7 +43,7 @@ async function prefetchQueries(searchParams: HomePageProps['searchParams']) { categoryId = categories?.data?.find((category) => { return `"${category.attributes?.slug}"` === searchParams.category; - })?.id; + })?.attributes?.slug; } const params = getStoriesParams(categoryId ? { category: categoryId } : {}); diff --git a/client/src/app/(landing)/stories/[id]/page.tsx b/client/src/app/(landing)/stories/[id]/page.tsx index 9f33b2d..6e428dd 100644 --- a/client/src/app/(landing)/stories/[id]/page.tsx +++ b/client/src/app/(landing)/stories/[id]/page.tsx @@ -10,32 +10,6 @@ import Story from '@/containers/story'; type StoryPageProps = { params: { id: string } }; -// You can't generate static params for dynamic routes if they are using useSearchParams https://nextjs.org/docs/messages/deopted-into-client-rendering -// The solution is to wrap the component with Suspense -// By doing this, we will have errors related to hydration -// As we use it inside RecoilURLSyncNext, we can't generate static params - -// export async function generateStaticParams() { -// try { -// const { data: storiesData } = await getStories({ -// 'pagination[limit]': 200, -// }); - -// if (!storiesData) { -// throw new Error('Failed to parse storiesData'); -// } - -// console.log('storiesData', storiesData); - -// return storiesData.map((s) => ({ -// id: `${s.id}`, -// })); -// } catch (e) { -// console.error(e); -// return []; -// } -// } - export async function generateMetadata({ params }: StoryPageProps): Promise { try { // read route params diff --git a/client/src/components/map/constants.ts b/client/src/components/map/constants.ts index 31d8ebd..43f7f6d 100644 --- a/client/src/components/map/constants.ts +++ b/client/src/components/map/constants.ts @@ -1,7 +1,16 @@ import type { ViewState } from 'react-map-gl'; +import { CustomMapProps } from './types'; + export const DEFAULT_VIEW_STATE: Partial = { zoom: 2, latitude: 0, longitude: 0, }; + +export const DEFAULT_PROPS: CustomMapProps = { + id: 'default', + initialViewState: DEFAULT_VIEW_STATE, + minZoom: 1, + maxZoom: 14, +}; diff --git a/client/src/components/map/legend/index.tsx b/client/src/components/map/legend/index.tsx index e2ebe43..25f2ec4 100644 --- a/client/src/components/map/legend/index.tsx +++ b/client/src/components/map/legend/index.tsx @@ -23,28 +23,28 @@ export const Legend: React.FC = ({ isChildren && (
{isChildren && ( -
+
{!!sortable?.enabled && !!onChangeOrder ? ( {children} ) : Array.isArray(children) && children.length > 1 ? ( - + - Legends + Legend - + {children} ) : ( - children +
{children}
)}
)} diff --git a/client/src/components/map/legend/item-types/basic/index.tsx b/client/src/components/map/legend/item-types/basic/index.tsx index f9875cf..e3842dd 100644 --- a/client/src/components/map/legend/item-types/basic/index.tsx +++ b/client/src/components/map/legend/item-types/basic/index.tsx @@ -13,7 +13,7 @@ export const LegendTypeBasic: React.FC = ({ }) => { return (
diff --git a/client/src/components/map/legend/item-types/choropleth/index.tsx b/client/src/components/map/legend/item-types/choropleth/index.tsx index 310219f..687c41f 100644 --- a/client/src/components/map/legend/item-types/choropleth/index.tsx +++ b/client/src/components/map/legend/item-types/choropleth/index.tsx @@ -13,7 +13,7 @@ export const LegendTypeChoropleth: React.FC = ({ }) => { return (
diff --git a/client/src/components/map/legend/item-types/gradient/index.tsx b/client/src/components/map/legend/item-types/gradient/index.tsx index 9fc8629..a4ed51c 100644 --- a/client/src/components/map/legend/item-types/gradient/index.tsx +++ b/client/src/components/map/legend/item-types/gradient/index.tsx @@ -13,7 +13,7 @@ export const LegendTypeGradient: React.FC = ({ }) => { return (
diff --git a/client/src/components/map/legend/item-types/header.tsx b/client/src/components/map/legend/item-types/header.tsx index 5ff7f5b..6d30dc6 100644 --- a/client/src/components/map/legend/item-types/header.tsx +++ b/client/src/components/map/legend/item-types/header.tsx @@ -10,7 +10,7 @@ type LegendHeaderProps = { const LegendHeader = ({ title, info }: LegendHeaderProps) => { return ( -
+
{!!title &&
{title}
} {!!info && ( diff --git a/client/src/components/map/legend/item-types/matrix/index.tsx b/client/src/components/map/legend/item-types/matrix/index.tsx index 03d9fa2..374d46c 100644 --- a/client/src/components/map/legend/item-types/matrix/index.tsx +++ b/client/src/components/map/legend/item-types/matrix/index.tsx @@ -10,7 +10,7 @@ export const LegendTypeMatrix: React.FC { return ( -
+

Always diff --git a/client/src/components/map/legend/item-types/switch/index.tsx b/client/src/components/map/legend/item-types/switch/index.tsx index 91a2e29..1ed7b61 100644 --- a/client/src/components/map/legend/item-types/switch/index.tsx +++ b/client/src/components/map/legend/item-types/switch/index.tsx @@ -34,7 +34,7 @@ const LegendTypeSwitch = ({ ); return ( -

+