From a525286384a0c37e117ba218aa396df72cfac51d Mon Sep 17 00:00:00 2001 From: BrickheadJohnny Date: Thu, 12 Dec 2024 13:08:31 +0100 Subject: [PATCH] feat: basic access indicators --- .../[guildUrlName]/[pageUrlName]/page.tsx | 70 ++++++++++++++++--- 1 file changed, 62 insertions(+), 8 deletions(-) diff --git a/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx b/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx index 9e0cf3b3a0..50649ba9a3 100644 --- a/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx +++ b/src/app/(dashboard)/[guildUrlName]/[pageUrlName]/page.tsx @@ -2,15 +2,17 @@ import { RequirementDisplayComponent } from "@/components/requirements/RequirementDisplayComponent"; import { rewardCards } from "@/components/rewards/rewardCards"; -import { Button } from "@/components/ui/Button"; +import { Badge } from "@/components/ui/Badge"; +import { Button, buttonVariants } from "@/components/ui/Button"; import { Card } from "@/components/ui/Card"; import { Skeleton } from "@/components/ui/Skeleton"; +import { cn } from "@/lib/cssUtils"; import { fetchGuildApiData } from "@/lib/fetchGuildApi"; -import { roleBatchOptions } from "@/lib/options"; +import { roleBatchOptions, userOptions } from "@/lib/options"; import type { GuildReward, GuildRewardType } from "@/lib/schemas/guildReward"; import type { Role } from "@/lib/schemas/role"; -import { ImageSquare, Lock } from "@phosphor-icons/react/dist/ssr"; -import { useSuspenseQuery } from "@tanstack/react-query"; +import { Check, ImageSquare, LockSimple } from "@phosphor-icons/react/dist/ssr"; +import { useQuery, useSuspenseQuery } from "@tanstack/react-query"; import { useParams } from "next/navigation"; import { Suspense } from "react"; import { useGuild } from "../hooks/useGuild"; @@ -72,10 +74,8 @@ const RoleCard = ({ role }: { role: Role }) => ( REQUIREMENTS - + + {/* TODO group rules by access groups */} @@ -87,6 +87,8 @@ const RoleCard = ({ role }: { role: Role }) => ( /> ))} + + ); @@ -135,4 +137,56 @@ const RoleRewards = ({ ) : null; }; +// TODO: handle state during join & error/no access states too +const ACCESS_INDICATOR_CLASS = + "rounded-b-2xl rounded-t-none min-w-full justify-between sm:rounded-b-xl sm:rounded-t-xl sm:min-w-max"; +const AccessIndicator = ({ + roleId, + className, +}: { roleId: Role["id"]; className?: string }) => { + const { data: guild } = useGuild(); + + const { data: user } = useQuery(userOptions()); + const isGuildMember = user?.guilds?.find((g) => g.guildId === guild.id); + const isRoleMember = !!user?.guilds + ?.flatMap((g) => g.roles) + ?.find((r) => r?.roleId === roleId); + + if (!isGuildMember) + return ( + + ); + + if (!isRoleMember) + return ( + + ); + + return ( + + + You have access + + ); +}; + export default GuildPage;