umami/components/input/RefreshButton.js

33 lines
911 B
JavaScript
Raw Normal View History

import { LoadingButton, Icon, Tooltip } from 'react-basics';
import { setWebsiteDateRange } from 'store/websites';
import useDateRange from 'hooks/useDateRange';
2023-01-31 05:44:07 +00:00
import Icons from 'components/icons';
2023-03-22 21:05:55 +00:00
import useMessages from 'hooks/useMessages';
2023-04-21 15:00:42 +00:00
export function RefreshButton({ websiteId, isLoading }) {
2023-03-22 21:05:55 +00:00
const { formatMessage, labels } = useMessages();
const [dateRange] = useDateRange(websiteId);
2020-08-31 21:11:30 +00:00
function handleClick() {
if (!isLoading && dateRange) {
2023-01-31 05:44:07 +00:00
if (/^\d+/.test(dateRange.value)) {
setWebsiteDateRange(websiteId, dateRange.value);
2022-03-02 05:13:15 +00:00
} else {
setWebsiteDateRange(websiteId, dateRange);
2022-03-02 05:13:15 +00:00
}
2020-08-31 21:11:30 +00:00
}
}
return (
2023-02-04 16:59:52 +00:00
<Tooltip label={formatMessage(labels.refresh)}>
<LoadingButton loading={isLoading} onClick={handleClick}>
2023-02-04 16:59:52 +00:00
<Icon>
<Icons.Refresh />
</Icon>
</LoadingButton>
2023-02-04 16:59:52 +00:00
</Tooltip>
);
}
export default RefreshButton;