import React from "react"; // ui import { CustomSelect } from "components/ui"; // icons import { getPriorityIcon } from "components/icons/priority-icon"; // types import { IIssue } from "types"; // constants import { PRIORITIES } from "constants/project"; type Props = { issue: IIssue; partialUpdateIssue: (formData: Partial) => void; position?: "left" | "right"; isNotAllowed: boolean; }; export const ViewPrioritySelect: React.FC = ({ issue, partialUpdateIssue, position = "right", isNotAllowed, }) => ( {getPriorityIcon( issue.priority && issue.priority !== "" ? issue.priority ?? "" : "None", "text-sm" )} } value={issue.state} onChange={(data: string) => { partialUpdateIssue({ priority: data }); }} maxHeight="md" buttonClassName={`flex ${ isNotAllowed ? "cursor-not-allowed" : "cursor-pointer" } items-center gap-x-2 rounded px-2 py-0.5 capitalize shadow-sm focus:border-indigo-500 focus:outline-none focus:ring-1 focus:ring-indigo-500 ${ issue.priority === "urgent" ? "bg-red-100 text-red-600 hover:bg-red-100" : issue.priority === "high" ? "bg-orange-100 text-orange-500 hover:bg-orange-100" : issue.priority === "medium" ? "bg-yellow-100 text-yellow-500 hover:bg-yellow-100" : issue.priority === "low" ? "bg-green-100 text-green-500 hover:bg-green-100" : "bg-gray-100" } border-none`} noChevron disabled={isNotAllowed} > {PRIORITIES?.map((priority) => ( <> {getPriorityIcon(priority, "text-sm")} {priority ?? "None"} ))} );