All files / app/components/Navigation ReportButton.tsx

93.75% Statements 15/16
80% Branches 4/5
80% Functions 4/5
93.33% Lines 14/15

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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 691x 1x 1x 1x 1x 1x   1x   23x                         11x             23x 23x 23x                                           9x                   3x          
import { darken, styled, Typography, useMediaQuery } from "@mui/material";
import Button from "components/Button";
import { BugIcon } from "components/Icons";
import { useTranslation } from "i18n";
import { useState } from "react";
import { theme } from "theme";
 
import ReportDialog from "./ReportDialog";
 
const StyledReportButton = styled(Button)(() => ({
  flexShrink: 0,
  backgroundColor: theme.palette.error.main,
  "&:hover": {
    backgroundColor: darken(theme.palette.error.main, 0.1),
  },
  "& .MuiButton-startIcon": {
    [theme.breakpoints.down("md")]: {
      margin: 0,
    },
  },
}));
 
export default function ReportButton({
  isResponsive = true,
  isMenuLink,
}: {
  isResponsive?: boolean;
  isMenuLink?: boolean;
}) {
  const { t } = useTranslation("global");
  const isBelowMd = useMediaQuery(theme.breakpoints.down("md"));
  const [isDialogOpen, setIsDialogOpen] = useState(false);
 
  return (
    <>
      {isMenuLink ? (
        <Typography
          aria-label={t("report.label")}
          onClick={() => setIsDialogOpen(true)}
          sx={{
            color: theme.palette.text.secondary,
            cursor: "pointer",
 
            "&:hover": {
              textDecoration: "underline",
            },
          }}
        >
          {t("report.label")}
        </Typography>
      ) : (
        <StyledReportButton
          aria-label={t("report.label")}
          onClick={() => setIsDialogOpen(true)}
          startIcon={<BugIcon />}
          variant="contained"
          color="primary"
        >
          {(!isResponsive || !isBelowMd) && t("report.label")}
        </StyledReportButton>
      )}
      <ReportDialog
        open={isDialogOpen}
        onClose={() => setIsDialogOpen(false)}
      />
    </>
  );
}