umami/hooks/useDateRange.js

29 lines
946 B
JavaScript

import { useSelector } from 'react-redux';
import { parseISO } from 'date-fns';
import { getDateRange } from 'lib/date';
import { getItem } from 'lib/web';
export default function useDateRange(websiteId, defaultDateRange = '24hour') {
const globalDefault = getItem('umami.date-range');
let globalDateRange;
if (typeof globalDefault === 'string') {
globalDateRange = getDateRange(globalDefault);
} else {
globalDateRange = {
...globalDefault,
startDate:
globalDefault && globalDefault.startDate
? parseISO(globalDefault.startDate)
: new Date(Date.now() - 604800000), // set 7 days agao as default start date if no globalDefault
endDate:
globalDefault && globalDefault.endDate ? parseISO(globalDefault.endDate) : new Date(),
};
}
return useSelector(
state =>
state.websites[websiteId]?.dateRange || globalDateRange || getDateRange(defaultDateRange),
);
}