mirror of
https://github.com/kremalicious/umami.git
synced 2025-02-14 21:10:34 +01:00
45 lines
1.1 KiB
TypeScript
45 lines
1.1 KiB
TypeScript
import { useMemo } from 'react';
|
|
import { StatusLight } from 'react-basics';
|
|
import { useApi } from 'components/hooks';
|
|
import { useMessages } from 'components/hooks';
|
|
import styles from './ActiveUsers.module.css';
|
|
|
|
export function ActiveUsers({
|
|
websiteId,
|
|
value,
|
|
refetchInterval = 60000,
|
|
}: {
|
|
websiteId: string;
|
|
value?: number;
|
|
refetchInterval?: number;
|
|
}) {
|
|
const { formatMessage, messages } = useMessages();
|
|
const { get, useQuery } = useApi();
|
|
const { data } = useQuery({
|
|
queryKey: ['websites:active', websiteId],
|
|
queryFn: () => get(`/websites/${websiteId}/active`),
|
|
enabled: !!websiteId,
|
|
refetchInterval,
|
|
});
|
|
|
|
const count = useMemo(() => {
|
|
if (websiteId) {
|
|
return data?.x || 0;
|
|
}
|
|
|
|
return value !== undefined ? value : 0;
|
|
}, [data, value, websiteId]);
|
|
|
|
if (count === 0) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<StatusLight className={styles.container} variant="success">
|
|
<div className={styles.text}>{formatMessage(messages.activeUsers, { x: count })}</div>
|
|
</StatusLight>
|
|
);
|
|
}
|
|
|
|
export default ActiveUsers;
|