1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
import { Button, Icon, ListItem, Row, Select, Text } from '@umami/react-zen';
import { isAfter } from 'date-fns';
import { useMemo } from 'react';
import { useDateRange, useDateRangeQuery, useMessages, useNavigation } from '@/components/hooks';
import { ChevronRight } from '@/components/icons';
import { getDateRangeValue } from '@/lib/date';
import { DateFilter } from './DateFilter';
export interface WebsiteDateFilterProps {
websiteId: string;
compare?: string;
showAllTime?: boolean;
showButtons?: boolean;
allowCompare?: boolean;
}
export function WebsiteDateFilter({
websiteId,
showAllTime = true,
showButtons = true,
allowCompare,
}: WebsiteDateFilterProps) {
const { dateRange, isAllTime, isCustomRange } = useDateRange();
const { formatMessage, labels } = useMessages();
const {
router,
updateParams,
query: { compare = 'prev', offset = 0 },
} = useNavigation();
const disableForward = isAllTime || isAfter(dateRange.endDate, new Date());
const showCompare = allowCompare && !isAllTime;
const websiteDateRange = useDateRangeQuery(websiteId);
const handleChange = (date: string) => {
if (date === 'all') {
router.push(
updateParams({
date: `${getDateRangeValue(websiteDateRange.startDate, websiteDateRange.endDate)}:all`,
offset: undefined,
}),
);
} else {
router.push(updateParams({ date, offset: undefined }));
}
};
const handleIncrement = increment => {
router.push(updateParams({ offset: Number(offset) + increment }));
};
const handleSelect = (compare: any) => {
router.push(updateParams({ compare }));
};
const dateValue = useMemo(() => {
return offset !== 0
? getDateRangeValue(dateRange.startDate, dateRange.endDate)
: dateRange.value;
}, [dateRange]);
return (
<Row wrap="wrap" gap>
{showButtons && !isAllTime && !isCustomRange && (
<Row gap="1">
<Button onPress={() => handleIncrement(-1)} variant="outline">
<Icon rotate={180}>
<ChevronRight />
</Icon>
</Button>
<Button onPress={() => handleIncrement(1)} variant="outline" isDisabled={disableForward}>
<Icon>
<ChevronRight />
</Icon>
</Button>
</Row>
)}
<Row minWidth="200px">
<DateFilter
value={dateValue}
onChange={handleChange}
showAllTime={showAllTime}
renderDate={+offset !== 0}
/>
</Row>
{showCompare && (
<Row alignItems="center" gap>
<Text weight="bold">VS</Text>
<Row width="200px">
<Select
value={compare}
onChange={handleSelect}
popoverProps={{ style: { width: 200 } }}
>
<ListItem id="prev">{formatMessage(labels.previousPeriod)}</ListItem>
<ListItem id="yoy">{formatMessage(labels.previousYear)}</ListItem>
</Select>
</Row>
</Row>
)}
</Row>
);
}
|