All files / src/components/forms PrioritySelect.tsx

0% Statements 0/19
0% Branches 0/13
0% Functions 0/4
0% Lines 0/18

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 69                                                                                                                                         
import React, { FC, useMemo } from "react";
import l10n from "shared/lib/lang/l10n";
import { DropdownButton } from "ui/buttons/DropdownButton";
import {
  BlankIcon,
  CheckIcon,
  PriorityHighIcon,
  PriorityLowIcon,
  PriorityMediumIcon,
} from "ui/icons/Icons";
import { MenuGroup, MenuItem, MenuItemIcon } from "ui/menu/Menu";
import { FlexGrow } from "ui/spacing/Spacing";
import styled from "styled-components";
 
const priorities = ["high", "medium", "low"] as const;
export type Priority = typeof priorities[number];
 
interface PrioritySelectProps {
  value?: Priority;
  onChange?: (newValue: Priority) => void;
}
 
const priorityIconsLookup: Record<Priority, JSX.Element> = {
  low: <PriorityLowIcon />,
  medium: <PriorityMediumIcon />,
  high: <PriorityHighIcon />,
};
 
const MenuSpacer = styled.div`
  width: 10px;
`;
 
export const PrioritySelect: FC<PrioritySelectProps> = ({
  value = "low",
  onChange,
}) => {
  const selectedIcon = value ? priorityIconsLookup[value] : <PriorityLowIcon />;
  const priorityNamesLookup: Record<Priority, string> = useMemo(
    () => ({
      low: l10n("FIELD_LOW"),
      medium: l10n("FIELD_MEDIUM"),
      high: l10n("FIELD_HIGH"),
    }),
    []
  );
 
  const title = `${l10n("FIELD_PRIORITY")}${value ? ": " : ""}${
    value ? priorityNamesLookup[value] : ""
  }`;
  return (
    <DropdownButton label={selectedIcon} showArrow={false} title={title}>
      <MenuGroup>{l10n("FIELD_PRIORITY")}</MenuGroup>
      {priorities.map((priority) => (
        <MenuItem
          key={priority}
          onClick={() => {
            onChange?.(priority);
          }}
          icon={value === priority ? <CheckIcon /> : <BlankIcon />}
        >
          <FlexGrow>{priorityNamesLookup[priority]}</FlexGrow>
          <MenuSpacer />
          <MenuItemIcon>{priorityIconsLookup[priority]}</MenuItemIcon>
        </MenuItem>
      ))}
    </DropdownButton>
  );
};