// react import React, { useState } from "react"; import { useRouter } from "next/router"; import useSWR from "swr"; // icons import { ChevronDown } from "lucide-react"; // services import { ProjectService } from "services/project"; // fetch key import { PROJECT_MEMBERS } from "constants/fetch-keys"; // components import { Avatar } from "components/ui/avatar"; import { WebViewModal } from "./web-view-modal"; type Props = { value: string[]; onChange: (value: any) => void; disabled?: boolean; }; // services const projectService = new ProjectService(); export const AssigneeSelect: React.FC = (props) => { const { value, onChange, disabled = false } = props; const [isOpen, setIsOpen] = useState(false); const router = useRouter(); const { workspaceSlug, projectId } = router.query; const { data: members } = useSWR( workspaceSlug && projectId ? PROJECT_MEMBERS(projectId as string) : null, workspaceSlug && projectId ? () => projectService.fetchProjectMembers(workspaceSlug as string, projectId as string) : null ); const selectedAssignees = members?.filter((member) => value?.includes(member.member.id)); return ( <> { setIsOpen(false); }} > ({ label: member.member.display_name, value: member.member.id, checked: value?.includes(member.member.id), icon: , onClick: () => { setIsOpen(false); if (disabled) return; onChange(member.member.id); }, })) || [] } /> ); };