0
Fork 0
mirror of https://github.com/logto-io/logto.git synced 2025-01-06 20:40:08 -05:00

feat(console): add date picker in dashboard (#1085)

This commit is contained in:
Wang Sijie 2022-06-09 16:58:10 +08:00 committed by GitHub
parent bcc05e521d
commit 5a073ceb60
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 27 additions and 4 deletions

View file

@ -29,7 +29,7 @@ const Block = ({ varient = 'default', count, delta, title }: Props) => {
<div className={styles.number}>{formatNumberWithComma(count)}</div> <div className={styles.number}>{formatNumberWithComma(count)}</div>
{delta !== undefined && ( {delta !== undefined && (
<div className={classNames(styles.delta, delta < 0 && styles.down)}> <div className={classNames(styles.delta, delta < 0 && styles.down)}>
<span>(${deltaLable})</span> <span>({deltaLable})</span>
{delta > 0 && <ArrowUp />} {delta > 0 && <ArrowUp />}
{delta < 0 && <ArrowDown />} {delta < 0 && <ArrowDown />}
</div> </div>

View file

@ -28,6 +28,17 @@
margin-bottom: _.unit(4); margin-bottom: _.unit(4);
} }
.activeCard {
position: relative;
.datePicker {
position: absolute;
right: _.unit(6);
top: _.unit(6);
width: 160px;
}
}
.curve { .curve {
margin: _.unit(10) 0 _.unit(6); margin: _.unit(10) 0 _.unit(6);
width: 100%; width: 100%;

View file

@ -1,4 +1,5 @@
import React from 'react'; import dayjs from 'dayjs';
import React, { ChangeEventHandler, useState } from 'react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
import { import {
Area, Area,
@ -12,6 +13,7 @@ import {
import useSWR from 'swr'; import useSWR from 'swr';
import Card from '@/components/Card'; import Card from '@/components/Card';
import TextInput from '@/components/TextInput';
import Block from './components/Block'; import Block from './components/Block';
import Skeleton from './components/Skeleton'; import Skeleton from './components/Skeleton';
@ -19,13 +21,20 @@ import * as styles from './index.module.scss';
import { ActiveUsersResponse, NewUsersResponse, TotalUsersResponse } from './types'; import { ActiveUsersResponse, NewUsersResponse, TotalUsersResponse } from './types';
const Dashboard = () => { const Dashboard = () => {
const [date, setDate] = useState<string>(dayjs().format('YYYY-MM-DD'));
const { data: totalData } = useSWR<TotalUsersResponse>('/api/dashboard/users/total'); const { data: totalData } = useSWR<TotalUsersResponse>('/api/dashboard/users/total');
const { data: newData } = useSWR<NewUsersResponse>('/api/dashboard/users/new'); const { data: newData } = useSWR<NewUsersResponse>('/api/dashboard/users/new');
const { data: activeData } = useSWR<ActiveUsersResponse>('/api/dashboard/users/active'); const { data: activeData } = useSWR<ActiveUsersResponse>(
`/api/dashboard/users/active?date=${date}`
);
const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' }); const { t } = useTranslation(undefined, { keyPrefix: 'admin_console' });
const isLoading = !totalData || !newData || !activeData; const isLoading = !totalData || !newData || !activeData;
const handleDateChange: ChangeEventHandler<HTMLInputElement> = (event) => {
setDate(event.target.value);
};
return ( return (
<div className={styles.container}> <div className={styles.container}>
<div className={styles.header}> <div className={styles.header}>
@ -48,13 +57,16 @@ const Dashboard = () => {
delta={newData.last7Days.delta} delta={newData.last7Days.delta}
/> />
</div> </div>
<Card> <Card className={styles.activeCard}>
<Block <Block
title="dashboard.daily_active_users" title="dashboard.daily_active_users"
count={activeData.dau.count} count={activeData.dau.count}
delta={activeData.dau.delta} delta={activeData.dau.delta}
varient="plain" varient="plain"
/> />
<div className={styles.datePicker}>
<TextInput type="date" value={date} onChange={handleDateChange} />
</div>
<div className={styles.curve}> <div className={styles.curve}>
<ResponsiveContainer> <ResponsiveContainer>
<AreaChart <AreaChart