From ef32cef718d7434df373597bb494ecadcc2912c7 Mon Sep 17 00:00:00 2001 From: kakiba <97882386+kotto5@users.noreply.github.com> Date: Sat, 17 Feb 2024 13:42:31 +0900 Subject: [PATCH] =?UTF-8?q?[frontend]=20=E5=85=A8=E3=81=A6=E3=81=AEpage=20?= =?UTF-8?q?=E3=81=AEavatar=E3=81=8B=E3=82=89=20=E3=81=A7online=20status=20?= =?UTF-8?q?=E3=82=92=E7=A2=BA=E8=AA=8D=E3=81=A7=E3=81=8D=E3=82=8B=E3=82=88?= =?UTF-8?q?=E3=81=86=E3=81=AB=E3=81=99=E3=82=8B=20(#268)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * [frontend] avatar.tsx で useContext を用いて、onlineStatus を取得する また、Context を使うために avatar component を client component にした * [frontend] avatar の props の変更に対応 (user id を渡す) * [frontend] avatar props の id を 必須でなくした 利用するコンポーネントにid を持っていない可能性のあるコンポーネントがあったため --- frontend/app/pong/GameCard.tsx | 2 +- frontend/app/room/[id]/sidebar-item.tsx | 6 +++++- frontend/app/ui/room/ban-item.tsx | 2 +- frontend/app/ui/room/invite-item.tsx | 2 +- frontend/app/ui/room/message-item.tsx | 1 + frontend/app/ui/room/unban-item.tsx | 2 +- frontend/app/ui/settings/avatar-form.tsx | 10 ++++++++-- frontend/app/ui/settings/profile-form.tsx | 2 +- frontend/app/ui/user/avatar.tsx | 13 +++++++++++-- frontend/app/ui/user/match-history.tsx | 1 + frontend/app/ui/user/user-list.tsx | 3 +-- frontend/app/user/[id]/page.tsx | 2 +- 12 files changed, 33 insertions(+), 13 deletions(-) diff --git a/frontend/app/pong/GameCard.tsx b/frontend/app/pong/GameCard.tsx index 242cf7d4..6dd3e111 100644 --- a/frontend/app/pong/GameCard.tsx +++ b/frontend/app/pong/GameCard.tsx @@ -17,7 +17,7 @@ function UserCard({ user }: { user: PublicUserEntity }) { size="medium" href={`/user/${user.id}`} alt={user.name} - online={true} + id={user.id} /> diff --git a/frontend/app/room/[id]/sidebar-item.tsx b/frontend/app/room/[id]/sidebar-item.tsx index ea2dd41f..ba6fd317 100644 --- a/frontend/app/room/[id]/sidebar-item.tsx +++ b/frontend/app/room/[id]/sidebar-item.tsx @@ -110,7 +110,11 @@ export default function SidebarItem({ <> - + {truncateString(user.user.name, 15)} {room.accessLevel !== "DIRECT" && isUserOwner && " 👑"} diff --git a/frontend/app/ui/room/ban-item.tsx b/frontend/app/ui/room/ban-item.tsx index 5d3ec6db..4358ce44 100644 --- a/frontend/app/ui/room/ban-item.tsx +++ b/frontend/app/ui/room/ban-item.tsx @@ -39,7 +39,7 @@ export default function BanItem({ return (
- +
{user.name} diff --git a/frontend/app/ui/room/invite-item.tsx b/frontend/app/ui/room/invite-item.tsx index 9422f06c..7596d297 100644 --- a/frontend/app/ui/room/invite-item.tsx +++ b/frontend/app/ui/room/invite-item.tsx @@ -39,7 +39,7 @@ export default function InviteItem({ return (
- +
{user.name} diff --git a/frontend/app/ui/room/message-item.tsx b/frontend/app/ui/room/message-item.tsx index a379f7d4..e0b66662 100644 --- a/frontend/app/ui/room/message-item.tsx +++ b/frontend/app/ui/room/message-item.tsx @@ -21,6 +21,7 @@ export function MessageItem({ avatarURL={message.user.avatarURL} size="medium" href={`/user/${message.user.id}`} + id={message.user.id} > )} diff --git a/frontend/app/ui/room/unban-item.tsx b/frontend/app/ui/room/unban-item.tsx index 3d9e92c9..f631d11c 100644 --- a/frontend/app/ui/room/unban-item.tsx +++ b/frontend/app/ui/room/unban-item.tsx @@ -39,7 +39,7 @@ export default function UnbanItem({ return (
- +
{user.name} diff --git a/frontend/app/ui/settings/avatar-form.tsx b/frontend/app/ui/settings/avatar-form.tsx index 13354fa3..84dd8f2e 100644 --- a/frontend/app/ui/settings/avatar-form.tsx +++ b/frontend/app/ui/settings/avatar-form.tsx @@ -2,7 +2,13 @@ import { uploadAvatar } from "@/app/lib/actions"; import { Avatar } from "@/app/ui/user/avatar"; import { useRef } from "react"; -export default function AvatarForm({ avatarURL }: { avatarURL?: string }) { +export default function AvatarForm({ + avatarURL, + id, +}: { + avatarURL?: string; + id?: number; +}) { const inputRef = useRef(null); const submitAvatarForm = () => { const form = document.getElementById("avatar-form") as HTMLFormElement; @@ -11,7 +17,7 @@ export default function AvatarForm({ avatarURL }: { avatarURL?: string }) { return (
- + diff --git a/frontend/app/ui/user/avatar.tsx b/frontend/app/ui/user/avatar.tsx index 2e71db43..0d6d83ee 100644 --- a/frontend/app/ui/user/avatar.tsx +++ b/frontend/app/ui/user/avatar.tsx @@ -1,3 +1,5 @@ +"use client"; + import { Skeleton } from "@/components/ui/skeleton"; import { Tooltip, @@ -6,6 +8,8 @@ import { TooltipTrigger, } from "@/components/ui/tooltip"; import Link from "next/link"; +import { useContext } from "react"; +import { OnlineContext } from "@/app/lib/hooks/useOnlineStatus"; export type AvatarSize = "small" | "medium" | "large"; @@ -14,11 +18,16 @@ export interface Props { size: AvatarSize; href?: string; alt?: string; - online?: boolean; + id?: number; } -export function Avatar({ avatarURL, size, href, alt, online }: Props) { +export function Avatar({ avatarURL, size, href, alt, id }: Props) { + const onlineStatuses = useContext(OnlineContext); + const online = id ? onlineStatuses[id] : false; let sizeClass = ""; + if (!avatarURL) { + return ; + } let onlineStatusClass = online ? "bg-green-500 " : "bg-gray-500 "; switch (size) { case "small": diff --git a/frontend/app/ui/user/match-history.tsx b/frontend/app/ui/user/match-history.tsx index 1eee8f11..de027359 100644 --- a/frontend/app/ui/user/match-history.tsx +++ b/frontend/app/ui/user/match-history.tsx @@ -22,6 +22,7 @@ function MatchDetailItem({ avatarURL={detail.user.avatarURL} href={`/user/${detail.user.id}`} size="medium" + id={detail.user.id} />
{detail.user.name}
diff --git a/frontend/app/ui/user/user-list.tsx b/frontend/app/ui/user/user-list.tsx index 6368915f..9e16a38d 100644 --- a/frontend/app/ui/user/user-list.tsx +++ b/frontend/app/ui/user/user-list.tsx @@ -13,7 +13,6 @@ export default function UserList({ users: PublicUserEntity[]; avatarSize: AvatarSize; }) { - const onlineStatus = useContext(OnlineContext); return (
@@ -24,7 +23,7 @@ export default function UserList({ size={avatarSize} href={`/user/${u.id}`} alt={u.name} - online={onlineStatus[u.id] === 1} + id={u.id} key={u.id} /> ))} diff --git a/frontend/app/user/[id]/page.tsx b/frontend/app/user/[id]/page.tsx index cf7c328b..f30ab07c 100644 --- a/frontend/app/user/[id]/page.tsx +++ b/frontend/app/user/[id]/page.tsx @@ -47,7 +47,7 @@ export default async function FindUser({ return (
- +
{user.name}
{user.id !== currentUserId && (