-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathSetFilterButton.tsx
44 lines (42 loc) · 1.26 KB
/
SetFilterButton.tsx
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
import { Button, Typography, alpha } from "@mui/material";
import { FilterList } from "@mui/icons-material";
import React from "react";
import { SetFilterButtonProps } from "./SetFilterButton.types";
/**
* A button that represents a filter state. It accepts an onClick callback, and renders a label and a filter count.
*/
export function SetFilterButton({
onClick,
count = 0,
label = "Filters"
}: SetFilterButtonProps) {
// filter button label, with count if available (e.g. "Filters (3)")
const displayLabel = count > 0 ? `${label} (${count})` : `${label}`;
// color of the icon and text based on the filter count
const iconColor = count > 0 ? "primary" : "action";
const textColor = count > 0 ? "primary" : "textSecondary";
return (
<Button
data-testid="filter-open-button"
sx={theme => ({
"&:focus-visible": {
outline: `1px solid ${alpha(theme.palette.text.primary, 0.23)}`
},
width: "fit-content"
})}
disableRipple
onClick={onClick}
>
<FilterList color={iconColor} />
<Typography
variant="button"
flexGrow={1}
ml={1}
color={textColor}
data-testid="filter-open-text"
>
{displayLabel}
</Typography>
</Button>
);
}