import React, { useEffect } from "react"; import { useRouter } from "next/router"; import { observer } from "mobx-react-lite"; import { Controller, useForm } from "react-hook-form"; import { TwitterPicker } from "react-color"; import { Dialog, Popover, Transition } from "@headlessui/react"; import { ChevronDown } from "lucide-react"; // hooks import { useLabel } from "hooks/store"; import useToast from "hooks/use-toast"; // ui import { Button, Input } from "@plane/ui"; // types import type { IIssueLabel, IState } from "@plane/types"; // constants import { LABEL_COLOR_OPTIONS, getRandomLabelColor } from "constants/label"; // types type Props = { isOpen: boolean; projectId: string; handleClose: () => void; onSuccess?: (response: IIssueLabel) => void; }; const defaultValues: Partial = { name: "", color: "var(--color-neutral-110)", }; export const CreateLabelModal: React.FC = observer((props) => { const { isOpen, projectId, handleClose, onSuccess } = props; // router const router = useRouter(); const { workspaceSlug } = router.query; // store hooks const { createLabel } = useLabel(); // form info const { formState: { errors, isSubmitting }, handleSubmit, watch, control, reset, setValue, setFocus, } = useForm({ defaultValues, }); /** * For setting focus on name input */ useEffect(() => { setFocus("name"); }, [setFocus, isOpen]); useEffect(() => { if (isOpen) setValue("color", getRandomLabelColor()); }, [setValue, isOpen]); const onClose = () => { handleClose(); reset(defaultValues); }; const { setToastAlert } = useToast(); const onSubmit = async (formData: IIssueLabel) => { if (!workspaceSlug) return; await createLabel(workspaceSlug.toString(), projectId.toString(), formData) .then((res) => { onClose(); if (onSuccess) onSuccess(res); }) .catch((error) => { setToastAlert({ title: "Oops!", type: "error", message: error?.error ?? "Error while adding the label", }); reset(formData); }); }; return (
Create Label
{({ open, close }) => ( <> {watch("color") && watch("color") !== "" && ( )} ( { onChange(value.hex); close(); }} /> )} /> )}
( )} />
); });