- Reduce excessive scale values in animations (scale(50) → scale(3), scale(8) → scale(2.5)) - Add overflow: hidden to card-wrapper to prevent animation overflow - Remove "Favorite Card" heading from user page - Fix page width expanding issue caused by large-scale animations 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
82 lines
2.4 KiB
TypeScript
82 lines
2.4 KiB
TypeScript
import { useParams } from 'react-router-dom';
|
|
import { useQuery } from '@tanstack/react-query';
|
|
import Navigation from '../common/Navigation';
|
|
import CardGrid from '../card/CardGrid';
|
|
import UserProfile from '../user/UserProfile';
|
|
import SpecialCard from '../card/SpecialCard';
|
|
import { fetchUsers, fetchUserCards } from '../../utils/api';
|
|
|
|
export default function UserPage() {
|
|
const { username } = useParams<{ username: string }>();
|
|
|
|
const { data: users, isLoading } = useQuery({
|
|
queryKey: ['users'],
|
|
queryFn: () => fetchUsers(),
|
|
});
|
|
|
|
const user = users?.data.find(u => u.username === username);
|
|
|
|
const { data: cards, isLoading: cardsLoading } = useQuery({
|
|
queryKey: ['userCards', user?.id],
|
|
queryFn: () => fetchUserCards(user!.id),
|
|
enabled: !!user?.id,
|
|
});
|
|
|
|
if (!user && !isLoading) {
|
|
return (
|
|
<div className="min-h-screen">
|
|
<Navigation />
|
|
<div className="max-w-6xl mx-auto px-4 py-8">
|
|
<div className="text-center text-xl">User not found</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
if (!user) {
|
|
return (
|
|
<div className="min-h-screen flex items-center justify-center">
|
|
<div className="text-center">
|
|
<i className="fa-solid fa-spinner fa-spin text-6xl text-yellow-500"></i>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return (
|
|
<div className="min-h-screen">
|
|
<Navigation username={username} />
|
|
|
|
<div className="max-w-6xl mx-auto px-4">
|
|
<UserProfile user={user} cards={cards?.data || []} />
|
|
|
|
{cardsLoading ? (
|
|
<div className="text-center py-8">
|
|
<i className="fa-solid fa-spinner fa-spin text-4xl text-yellow-500"></i>
|
|
</div>
|
|
) : (
|
|
<>
|
|
{/* Favorite Card Section */}
|
|
{user.fav && user.fav !== '0' && cards?.data && (
|
|
(() => {
|
|
const favCard = cards.data.find(card => card.id === parseInt(user.fav));
|
|
if (favCard) {
|
|
return (
|
|
<div className="mb-8">
|
|
<div className="flex justify-center">
|
|
<SpecialCard card={favCard} />
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
return null;
|
|
})()
|
|
)}
|
|
|
|
<CardGrid cards={cards?.data || []} user={user} />
|
|
</>
|
|
)}
|
|
</div>
|
|
</div>
|
|
);
|
|
} |