umami/components/common/RefreshButton.js

29 lines
968 B
JavaScript
Raw Normal View History

import React, { useState, useEffect } from 'react';
import { useDispatch, useSelector } from 'react-redux';
2020-08-31 23:11:30 +02:00
import { setDateRange } from 'redux/actions/websites';
import Button from './Button';
import Refresh from 'assets/redo.svg';
import Dots from 'assets/ellipsis-h.svg';
2020-09-01 00:02:32 +02:00
import { useDateRange } from 'hooks/useDateRange';
2020-09-03 17:42:08 +02:00
import { getDateRange } from '../../lib/date';
2020-08-31 23:11:30 +02:00
export default function RefreshButton({ websiteId }) {
const dispatch = useDispatch();
2020-09-01 00:02:32 +02:00
const dateRange = useDateRange(websiteId);
const [loading, setLoading] = useState(false);
const completed = useSelector(state => state.queries[`/api/website/${websiteId}/metrics`]);
2020-08-31 23:11:30 +02:00
function handleClick() {
if (dateRange) {
setLoading(true);
2020-09-03 17:42:08 +02:00
dispatch(setDateRange(websiteId, getDateRange(dateRange.value)));
2020-08-31 23:11:30 +02:00
}
}
useEffect(() => {
setLoading(false);
}, [completed]);
return <Button icon={loading ? <Dots /> : <Refresh />} size="small" onClick={handleClick} />;
}