fix: displaying 0 whilst loading

This commit is contained in:
2026-03-10 13:47:27 +01:00
parent f177d6448d
commit 0ffd1e52ae
3 changed files with 17 additions and 27 deletions

View File

@@ -1,15 +1,11 @@
import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card' import { Card, CardContent, CardHeader, CardTitle } from '@/components/ui/card';
import { settingsAtom } from '@/lib/atoms' import { Coins } from 'lucide-react';
import { useAtom } from 'jotai' import { useTranslations } from 'next-intl';
import { Coins } from 'lucide-react' import TodayEarnedCoins from './TodayEarnedCoins';
import { useTranslations } from 'next-intl'
import dynamic from 'next/dynamic'
const TodayEarnedCoins = dynamic(() => import('./TodayEarnedCoins'), { ssr: false }) export default function CoinBalance({ coinBalance }: { coinBalance: number | undefined }) {
export default function CoinBalance({ coinBalance }: { coinBalance: number }) {
const t = useTranslations('CoinBalance'); const t = useTranslations('CoinBalance');
const [settings] = useAtom(settingsAtom)
return ( return (
<Card> <Card>
<CardHeader> <CardHeader>
@@ -20,7 +16,7 @@ export default function CoinBalance({ coinBalance }: { coinBalance: number }) {
<Coins className="h-12 w-12 text-yellow-400 mr-4" /> <Coins className="h-12 w-12 text-yellow-400 mr-4" />
<div className="flex flex-col"> <div className="flex flex-col">
<div className="flex flex-col"> <div className="flex flex-col">
<span className="text-4xl font-bold">{coinBalance}</span> <span className="text-4xl font-bold">{coinBalance ? coinBalance : "…"}</span>
<div className="flex items-center gap-1"> <div className="flex items-center gap-1">
<TodayEarnedCoins longFormat={true} /> <TodayEarnedCoins longFormat={true} />
</div> </div>

View File

@@ -357,12 +357,8 @@ export default function DailyOverview({
coinBalance, coinBalance,
}: UpcomingItemsProps) { }: UpcomingItemsProps) {
const t = useTranslations('DailyOverview'); const t = useTranslations('DailyOverview');
const { completeHabit, undoComplete } = useHabits()
const [settings] = useAtom(settingsAtom) const [settings] = useAtom(settingsAtom)
const [completedHabitsMap] = useAtom(completedHabitsMapAtom)
const [browserSettings, setBrowserSettings] = useAtom(browserSettingsAtom) const [browserSettings, setBrowserSettings] = useAtom(browserSettingsAtom)
const today = getTodayInTimezone(settings.system.timezone)
const todayCompletions = completedHabitsMap.get(today) || []
const { saveHabit } = useHabits() const { saveHabit } = useHabits()
const timezone = settings.system.timezone const timezone = settings.system.timezone

View File

@@ -1,7 +1,6 @@
'use client' 'use client'
import { useCoins } from '@/hooks/useCoins' import { coinsAtom, currentUserIdAtom, habitsAtom, wishlistAtom } from '@/lib/atoms'
import { habitsAtom, wishlistAtom } from '@/lib/atoms'
import { useAtom } from 'jotai' import { useAtom } from 'jotai'
import { useTranslations } from 'next-intl' import { useTranslations } from 'next-intl'
import CoinBalance from './CoinBalance' import CoinBalance from './CoinBalance'
@@ -10,11 +9,12 @@ import HabitStreak from './HabitStreak'
export default function Dashboard() { export default function Dashboard() {
const t = useTranslations('Dashboard'); const t = useTranslations('Dashboard');
const [habitsData] = useAtom(habitsAtom) const [{ habits }] = useAtom(habitsAtom);
const habits = habitsData.habits const [loggedInUserId] = useAtom(currentUserIdAtom);
const { balance } = useCoins() const [{ transactions }] = useAtom(coinsAtom);
const [wishlist] = useAtom(wishlistAtom) const [{ items }] = useAtom(wishlistAtom);
const wishlistItems = wishlist.items
const loggedInUserBalance = loggedInUserId ? transactions.filter(transaction => transaction.userId === loggedInUserId).reduce((sum, transaction) => sum + transaction.amount, 0) : 0;
return ( return (
<div> <div>
@@ -22,15 +22,13 @@ export default function Dashboard() {
<h1 className="text-xl xs:text-3xl font-bold">{t('title')}</h1> <h1 className="text-xl xs:text-3xl font-bold">{t('title')}</h1>
</div> </div>
<div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6"> <div className="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-6">
<CoinBalance coinBalance={balance} /> <CoinBalance coinBalance={loggedInUserId ? loggedInUserBalance : undefined} />
<HabitStreak habits={habits} /> <HabitStreak habits={habits} />
<DailyOverview <DailyOverview
wishlistItems={wishlistItems} wishlistItems={items}
habits={habits} habits={habits}
coinBalance={balance} coinBalance={loggedInUserBalance}
/> />
{/* <HabitHeatmap habits={habits} /> */}
</div> </div>
</div> </div>
) )