import { useState } from 'react'; import { Icon, Modal, Dropdown, Item, Text, Flexbox } from 'react-basics'; import { useIntl } from 'react-intl'; import { endOfYear, isSameDay } from 'date-fns'; import DatePickerForm from 'components/metrics/DatePickerForm'; import useLocale from 'hooks/useLocale'; import { dateFormat, getDateRangeValues } from 'lib/date'; import Icons from 'components/icons'; import { labels } from 'components/messages'; import useApi from 'hooks/useApi'; import useDateRange from 'hooks/useDateRange'; function DateFilter({ websiteId, value, className }) { const { formatMessage } = useIntl(); const { get } = useApi(); const [dateRange, setDateRange] = useDateRange(websiteId); const { startDate, endDate } = dateRange; const [showPicker, setShowPicker] = useState(false); async function handleDateChange(value) { if (value === 'all') { const data = await get(`/websites/${websiteId}`); if (data) { setDateRange({ value, ...getDateRangeValues(new Date(data.createdAt), Date.now()) }); } } else { setDateRange(value); } } const options = [ { label: formatMessage(labels.today), value: '1day' }, { label: formatMessage(labels.lastHours, { x: 24 }), value: '24hour', }, { label: formatMessage(labels.yesterday), value: '-1day', }, { label: formatMessage(labels.thisWeek), value: '1week', divider: true, }, { label: formatMessage(labels.lastDays, { x: 7 }), value: '7day', }, { label: formatMessage(labels.thisMonth), value: '1month', divider: true, }, { label: formatMessage(labels.lastDays, { x: 30 }), value: '30day', }, { label: formatMessage(labels.lastDays, { x: 90 }), value: '90day', }, { label: formatMessage(labels.thisYear), value: '1year' }, { label: formatMessage(labels.allTime), value: 'all', divider: true, }, { label: formatMessage(labels.customRange), value: 'custom', divider: true, }, ]; const renderValue = value => { return value === 'custom' ? ( handleChange('custom')} /> ) : ( options.find(e => e.value === value).label ); }; const handleChange = value => { if (value === 'custom') { setShowPicker(true); return; } handleDateChange(value); }; const handlePickerChange = value => { setShowPicker(false); handleDateChange(value); }; const handleClose = () => setShowPicker(false); return ( <> {({ label, value, divider }) => ( {label} )} {showPicker && ( setShowPicker(false)} /> )} ); } const CustomRange = ({ startDate, endDate, onClick }) => { const { locale } = useLocale(); function handleClick(e) { e.stopPropagation(); onClick(); } return ( {dateFormat(startDate, 'd LLL y', locale)} {!isSameDay(startDate, endDate) && ` — ${dateFormat(endDate, 'd LLL y', locale)}`} ); }; export default DateFilter;