2022-12-28 23:43:22 +00:00
|
|
|
import { useState, useEffect, useCallback } from 'react';
|
2023-02-04 16:59:52 +00:00
|
|
|
import { useIntl } from 'react-intl';
|
|
|
|
|
import { Button, Icon, Tooltip } from '../react-basics';
|
2022-02-23 06:47:59 +00:00
|
|
|
import useStore from 'store/queries';
|
|
|
|
|
import { setDateRange } from 'store/websites';
|
2020-09-18 05:52:20 +00:00
|
|
|
import useDateRange from 'hooks/useDateRange';
|
2023-01-31 05:44:07 +00:00
|
|
|
import Icons from 'components/icons';
|
2023-02-04 16:59:52 +00:00
|
|
|
import { labels } from 'components/messages';
|
2020-08-31 10:53:39 +00:00
|
|
|
|
2021-02-16 12:35:16 +00:00
|
|
|
function RefreshButton({ websiteId }) {
|
2023-02-04 16:59:52 +00:00
|
|
|
const { formatMessage } = useIntl();
|
2020-09-19 17:35:05 +00:00
|
|
|
const [dateRange] = useDateRange(websiteId);
|
2020-09-02 23:49:14 +00:00
|
|
|
const [loading, setLoading] = useState(false);
|
2022-10-04 00:17:53 +00:00
|
|
|
const selector = useCallback(state => state[`/websites/${websiteId}/stats`], [websiteId]);
|
2022-02-23 06:47:59 +00:00
|
|
|
const completed = useStore(selector);
|
2020-08-31 21:11:30 +00:00
|
|
|
|
|
|
|
|
function handleClick() {
|
2022-03-02 05:13:15 +00:00
|
|
|
if (!loading && dateRange) {
|
2020-09-02 23:49:14 +00:00
|
|
|
setLoading(true);
|
2023-01-31 05:44:07 +00:00
|
|
|
if (/^\d+/.test(dateRange.value)) {
|
2022-03-02 05:13:15 +00:00
|
|
|
setDateRange(websiteId, dateRange.value);
|
|
|
|
|
} else {
|
|
|
|
|
setDateRange(websiteId, dateRange);
|
|
|
|
|
}
|
2020-08-31 21:11:30 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-09-02 23:49:14 +00:00
|
|
|
useEffect(() => {
|
|
|
|
|
setLoading(false);
|
|
|
|
|
}, [completed]);
|
|
|
|
|
|
2020-09-16 03:34:30 +00:00
|
|
|
return (
|
2023-02-04 16:59:52 +00:00
|
|
|
<Tooltip label={formatMessage(labels.refresh)}>
|
|
|
|
|
<Button onClick={handleClick}>
|
|
|
|
|
<Icon>
|
|
|
|
|
<Icons.Refresh />
|
|
|
|
|
</Icon>
|
|
|
|
|
</Button>
|
|
|
|
|
</Tooltip>
|
2020-09-16 03:34:30 +00:00
|
|
|
);
|
2020-08-31 10:53:39 +00:00
|
|
|
}
|
2021-02-16 12:35:16 +00:00
|
|
|
|
|
|
|
|
export default RefreshButton;
|