From 6932741df8e6c51b1a51f5607e1828d9b33f5a2a Mon Sep 17 00:00:00 2001 From: BrickheadJohnny Date: Thu, 12 Dec 2024 13:12:24 +0100 Subject: [PATCH] feat: store join modal open state in an atom --- src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx | 6 ++++++ src/app/(dashboard)/[guildUrlName]/atoms.ts | 3 +++ .../(dashboard)/[guildUrlName]/components/JoinGuild.tsx | 8 +++++--- 3 files changed, 14 insertions(+), 3 deletions(-) create mode 100644 src/app/(dashboard)/[guildUrlName]/atoms.ts diff --git a/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx b/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx index 50649ba9a3..9ea27ca4f9 100644 --- a/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx +++ b/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx @@ -13,8 +13,10 @@ import type { GuildReward, GuildRewardType } from "@/lib/schemas/guildReward"; import type { Role } from "@/lib/schemas/role"; import { Check, ImageSquare, LockSimple } from "@phosphor-icons/react/dist/ssr"; import { useQuery, useSuspenseQuery } from "@tanstack/react-query"; +import { useSetAtom } from "jotai"; import { useParams } from "next/navigation"; import { Suspense } from "react"; +import { joinModalAtom } from "../atoms"; import { useGuild } from "../hooks/useGuild"; const GuildPage = () => { @@ -152,12 +154,15 @@ const AccessIndicator = ({ ?.flatMap((g) => g.roles) ?.find((r) => r?.roleId === roleId); + const onJoinModalOpenChange = useSetAtom(joinModalAtom); + if (!isGuildMember) return ( @@ -169,6 +174,7 @@ const AccessIndicator = ({ size="sm" leftIcon={} className={cn(ACCESS_INDICATOR_CLASS, className)} + onClick={() => onJoinModalOpenChange(true)} > Check access to collect rewards diff --git a/src/app/(dashboard)/[guildUrlName]/atoms.ts b/src/app/(dashboard)/[guildUrlName]/atoms.ts new file mode 100644 index 0000000000..f1b445154f --- /dev/null +++ b/src/app/(dashboard)/[guildUrlName]/atoms.ts @@ -0,0 +1,3 @@ +import { atom } from "jotai"; + +export const joinModalAtom = atom(false); diff --git a/src/app/(dashboard)/[guildUrlName]/components/JoinGuild.tsx b/src/app/(dashboard)/[guildUrlName]/components/JoinGuild.tsx index 2805434c10..d39bc562f2 100644 --- a/src/app/(dashboard)/[guildUrlName]/components/JoinGuild.tsx +++ b/src/app/(dashboard)/[guildUrlName]/components/JoinGuild.tsx @@ -20,9 +20,11 @@ import type { Schemas } from "@guildxyz/types"; import { Check, CheckCircle, XCircle } from "@phosphor-icons/react/dist/ssr"; import { useMutation, useQuery, useQueryClient } from "@tanstack/react-query"; import { EventSourcePlus } from "event-source-plus"; +import { useAtom } from "jotai"; import { useParams, useRouter, useSearchParams } from "next/navigation"; -import { type ReactNode, useEffect, useState } from "react"; +import { type ReactNode, useEffect } from "react"; import { toast } from "sonner"; +import { joinModalAtom } from "../atoms"; const JOIN_MODAL_SEARCH_PARAM = "join"; @@ -30,12 +32,12 @@ export const JoinGuild = () => { const searchParams = useSearchParams(); const shouldOpen = searchParams.has(JOIN_MODAL_SEARCH_PARAM); - const [open, onOpenChange] = useState(false); + const [open, onOpenChange] = useAtom(joinModalAtom); useEffect(() => { if (!shouldOpen) return; onOpenChange(true); - }, [shouldOpen]); + }, [shouldOpen, onOpenChange]); const { data: user } = useQuery(userOptions());