import { Dispatch, SetStateAction, useEffect, useMemo } from "react"; import { observer } from "mobx-react"; import { useRouter } from "next/router"; import { TIssue } from "@plane/types"; import { Loader, TOAST_TYPE, setToast } from "@plane/ui"; // components import { InboxIssueContentProperties } from "@/components/inbox/content"; import { IssueDescriptionInput, IssueTitleInput, IssueActivity, IssueReaction, TIssueOperations, IssueAttachmentRoot, } from "@/components/issues"; // constants import { E_INBOX, INBOX_ISSUE_UPDATED } from "@/constants/event-tracker"; // hooks import { useEventTracker, useProjectInbox, useUser } from "@/hooks/store"; import useReloadConfirmations from "@/hooks/use-reload-confirmation"; // store types import { IInboxIssueStore } from "@/store/inbox/inbox-issue.store"; type Props = { workspaceSlug: string; projectId: string; inboxIssue: IInboxIssueStore; isEditable: boolean; isSubmitting: "submitting" | "submitted" | "saved"; setIsSubmitting: Dispatch>; swrIssueDescription: string | undefined; }; export const InboxIssueMainContent: React.FC = observer((props) => { const router = useRouter(); const { workspaceSlug, projectId, inboxIssue, isEditable, isSubmitting, setIsSubmitting, swrIssueDescription } = props; // hooks const { data: currentUser } = useUser(); const { setShowAlert } = useReloadConfirmations(isSubmitting === "submitting"); const { captureEvent } = useEventTracker(); const { loader } = useProjectInbox(); useEffect(() => { if (isSubmitting === "submitted") { setShowAlert(false); setTimeout(async () => { setIsSubmitting("saved"); }, 3000); } else if (isSubmitting === "submitting") { setShowAlert(true); } }, [isSubmitting, setShowAlert, setIsSubmitting]); const issue = inboxIssue.issue; if (!issue) return <>; const issueOperations: TIssueOperations = useMemo( () => ({ // eslint-disable-next-line @typescript-eslint/no-unused-vars fetch: async (workspaceSlug: string, projectId: string, issueId: string) => { try { return; } catch (error) { setToast({ title: "Issue fetch failed", type: TOAST_TYPE.ERROR, message: "Issue fetch failed", }); } }, // eslint-disable-next-line @typescript-eslint/no-unused-vars remove: async (workspaceSlug: string, projectId: string, issueId: string) => { try { return; } catch (error) { setToast({ title: "Issue remove failed", type: TOAST_TYPE.ERROR, message: "Issue remove failed", }); } }, update: async (workspaceSlug: string, projectId: string, issueId: string, data: Partial) => { try { await inboxIssue.updateIssue(data); captureEvent(INBOX_ISSUE_UPDATED, { ...data, changed_property: Object.keys(data).join(","), change_details: Object.values(data).join(","), element: E_INBOX, state: "SUCCESS", }); } catch (error) { setToast({ title: "Issue update failed", type: TOAST_TYPE.ERROR, message: "Issue update failed", }); captureEvent(INBOX_ISSUE_UPDATED, { ...data, changed_property: Object.keys(data).join(","), change_details: Object.values(data).join(","), element: E_INBOX, state: "FAILED", }); } }, }), [inboxIssue] ); if (!issue?.project_id || !issue?.id) return <>; return ( <>
setIsSubmitting(value)} issueOperations={issueOperations} disabled={!isEditable} value={issue.name} /> {loader === "issue-loading" ? ( ) : (

"} disabled={!isEditable} issueOperations={issueOperations} setIsSubmitting={(value) => setIsSubmitting(value)} /> )} {currentUser && ( )}
); });