mirror of
https://github.com/ManInDark/HabitTrove.git
synced 2026-03-11 04:49:49 +01:00
fix: displaying 0 whilst loading
This commit is contained in:
@@ -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>
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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>
|
||||||
)
|
)
|
||||||
|
|||||||
Reference in New Issue
Block a user