import { useState } from 'react'; import { Loading } from 'react-basics'; import { useIntl } from 'react-intl'; import ErrorMessage from 'components/common/ErrorMessage'; import useApi from 'hooks/useApi'; import useDateRange from 'hooks/useDateRange'; import usePageQuery from 'hooks/usePageQuery'; import { formatShortTime, formatNumber, formatLongNumber } from 'lib/format'; import MetricCard from './MetricCard'; import { labels } from 'components/messages'; import styles from './MetricsBar.module.css'; export default function MetricsBar({ websiteId }) { const { formatMessage } = useIntl(); const { get, useQuery } = useApi(); const [dateRange] = useDateRange(websiteId); const { startDate, endDate, modified } = dateRange; const [format, setFormat] = useState(true); const { query: { url, referrer, os, browser, device, country }, } = usePageQuery(); const { data, error, isLoading, isFetched } = useQuery( ['websites:stats', { websiteId, modified, url, referrer, os, browser, device, country }], () => get(`/websites/${websiteId}/stats`, { startAt: +startDate, endAt: +endDate, url, referrer, os, browser, device, country, }), ); const formatFunc = format ? n => (n >= 0 ? formatLongNumber(n) : `-${formatLongNumber(Math.abs(n))}`) : formatNumber; function handleSetFormat() { setFormat(state => !state); } const { pageviews, uniques, bounces, totaltime } = data || {}; const num = Math.min(data && uniques.value, data && bounces.value); const diffs = data && { pageviews: pageviews.value - pageviews.change, uniques: uniques.value - uniques.change, bounces: bounces.value - bounces.change, totaltime: totaltime.value - totaltime.change, }; return (
{isLoading && !isFetched && } {error && } {data && !error && isFetched && ( <> Number(n).toFixed(0) + '%'} reverseColors /> `${n < 0 ? '-' : ''}${formatShortTime(Math.abs(~~n), ['m', 's'], ' ')}`} /> )}
); }