From 6d3857ef3580e9faf1f3b8a8ff8303b48c04aea4 Mon Sep 17 00:00:00 2001 From: Wang Sijie Date: Mon, 13 Jun 2022 13:50:48 +0800 Subject: [PATCH] feat(console): error handling in dashboard (#1090) --- .../console/src/pages/Dashboard/index.tsx | 23 +++++++++++++------ 1 file changed, 16 insertions(+), 7 deletions(-) diff --git a/packages/console/src/pages/Dashboard/index.tsx b/packages/console/src/pages/Dashboard/index.tsx index aa16087aa..5d3f0f162 100644 --- a/packages/console/src/pages/Dashboard/index.tsx +++ b/packages/console/src/pages/Dashboard/index.tsx @@ -12,8 +12,10 @@ import { } from 'recharts'; import useSWR from 'swr'; +import AppError from '@/components/AppError'; import Card from '@/components/Card'; import TextInput from '@/components/TextInput'; +import { RequestError } from '@/hooks/use-api'; import Block from './components/Block'; import Skeleton from './components/Skeleton'; @@ -21,15 +23,21 @@ import * as styles from './index.module.scss'; import { ActiveUsersResponse, NewUsersResponse, TotalUsersResponse } from './types'; const Dashboard = () => { - const [date, setDate] = useState(dayjs().format('YYYY-MM-DD')); - const { data: totalData } = useSWR('/api/dashboard/users/total'); - const { data: newData } = useSWR('/api/dashboard/users/new'); - const { data: activeData } = useSWR( - `/api/dashboard/users/active?date=${date}` + const { data: totalData, error: totalError } = useSWR( + '/api/dashboard/users/total' + ); + const { data: newData, error: newError } = useSWR( + '/api/dashboard/users/new' + ); + const { data: activeData, error: activeError } = useSWR( + '/api/dashboard/users/active' ); const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' }); + const [date, setDate] = useState(dayjs().format('YYYY-MM-DD')); - const isLoading = !totalData || !newData || !activeData; + // Pick an error as the page's error + const error = totalError ?? newError ?? activeError; + const isLoading = (!totalData || !newData || !activeData) && !error; const handleDateChange: ChangeEventHandler = (event) => { setDate(event.target.value); @@ -42,7 +50,8 @@ const Dashboard = () => {
{t('dashboard.description')}
{isLoading && } - {!isLoading && ( + {error && } + {!isLoading && totalData && newData && activeData && ( <>