2023-07-26 20:42:55 +00:00
|
|
|
import { getMinimumUnit, parseDateRange } from 'lib/date';
|
2023-03-09 00:37:43 +00:00
|
|
|
import { setItem } from 'next-basics';
|
2020-09-19 17:35:05 +00:00
|
|
|
import { DATE_RANGE_CONFIG, DEFAULT_DATE_RANGE } from 'lib/constants';
|
2023-03-09 04:23:32 +00:00
|
|
|
import websiteStore, { setWebsiteDateRange } from 'store/websites';
|
|
|
|
|
import appStore, { setDateRange } from 'store/app';
|
2023-12-09 08:35:54 +00:00
|
|
|
import { DateRange } from 'lib/types';
|
|
|
|
|
import useLocale from './useLocale';
|
2023-07-26 20:42:55 +00:00
|
|
|
import useApi from './useApi';
|
2020-08-31 22:02:32 +00:00
|
|
|
|
2023-12-03 11:07:03 +00:00
|
|
|
export function useDateRange(websiteId?: string) {
|
2023-07-26 20:42:55 +00:00
|
|
|
const { get } = useApi();
|
2021-06-30 01:41:34 +00:00
|
|
|
const { locale } = useLocale();
|
2023-03-09 04:23:32 +00:00
|
|
|
const websiteConfig = websiteStore(state => state[websiteId]?.dateRange);
|
2023-03-09 00:37:43 +00:00
|
|
|
const defaultConfig = DEFAULT_DATE_RANGE;
|
2023-03-09 04:23:32 +00:00
|
|
|
const globalConfig = appStore(state => state.dateRange);
|
|
|
|
|
const dateRange = parseDateRange(websiteConfig || globalConfig || defaultConfig, locale);
|
2020-09-19 17:35:05 +00:00
|
|
|
|
2023-12-09 08:35:54 +00:00
|
|
|
const saveDateRange = async (value: DateRange | string) => {
|
2020-09-19 17:35:05 +00:00
|
|
|
if (websiteId) {
|
2023-12-09 08:35:54 +00:00
|
|
|
let dateRange: DateRange | string = value;
|
2023-07-26 20:42:55 +00:00
|
|
|
|
|
|
|
|
if (typeof value === 'string') {
|
|
|
|
|
if (value === 'all') {
|
2023-11-14 05:36:52 +00:00
|
|
|
const result: any = await get(`/websites/${websiteId}/daterange`);
|
2023-07-26 20:42:55 +00:00
|
|
|
const { mindate, maxdate } = result;
|
|
|
|
|
|
|
|
|
|
const startDate = new Date(mindate);
|
|
|
|
|
const endDate = new Date(maxdate);
|
|
|
|
|
|
|
|
|
|
dateRange = {
|
|
|
|
|
startDate,
|
|
|
|
|
endDate,
|
|
|
|
|
unit: getMinimumUnit(startDate, endDate),
|
|
|
|
|
value,
|
|
|
|
|
};
|
|
|
|
|
} else {
|
|
|
|
|
dateRange = parseDateRange(value, locale);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2023-12-09 08:35:54 +00:00
|
|
|
setWebsiteDateRange(websiteId, dateRange as DateRange);
|
2020-09-19 17:35:05 +00:00
|
|
|
} else {
|
2023-03-09 00:37:43 +00:00
|
|
|
setItem(DATE_RANGE_CONFIG, value);
|
|
|
|
|
setDateRange(value);
|
2020-09-19 17:35:05 +00:00
|
|
|
}
|
2023-05-20 16:02:08 +00:00
|
|
|
};
|
2020-09-17 07:17:11 +00:00
|
|
|
|
2023-12-09 08:35:54 +00:00
|
|
|
return [dateRange, saveDateRange] as [
|
2024-01-15 05:17:11 +00:00
|
|
|
{ startDate: Date; endDate: Date; modified?: number; value?: string; unit?: string },
|
2023-12-09 08:35:54 +00:00
|
|
|
(value: string | DateRange) => void,
|
|
|
|
|
];
|
2020-08-31 22:02:32 +00:00
|
|
|
}
|
2023-05-18 06:20:06 +00:00
|
|
|
|
|
|
|
|
export default useDateRange;
|