From 72398fbf27af45838b319e0d291f95ec8d37144c Mon Sep 17 00:00:00 2001 From: Anmol Singh Bhatia Date: Fri, 23 Feb 2024 16:29:58 +0530 Subject: [PATCH 1/2] chore: trim issue title --- web/components/issues/title-input.tsx | 1 + 1 file changed, 1 insertion(+) diff --git a/web/components/issues/title-input.tsx b/web/components/issues/title-input.tsx index dbd18aaaa6f..2dd408fae4d 100644 --- a/web/components/issues/title-input.tsx +++ b/web/components/issues/title-input.tsx @@ -33,6 +33,7 @@ export const IssueTitleInput: FC = observer((props) => { useEffect(() => { if (debouncedValue && debouncedValue !== value) { issueOperations.update(workspaceSlug, projectId, issueId, { name: debouncedValue }, false).finally(() => { + setTitle(debouncedValue.trim()); setIsSubmitting("saved"); }); } From 4ccd92cb01f3ba613abeb9acd13224c4bb6ae498 Mon Sep 17 00:00:00 2001 From: Anmol Singh Bhatia Date: Sun, 25 Feb 2024 08:58:27 +0530 Subject: [PATCH 2/2] chore: issue title improvement --- web/components/issues/title-input.tsx | 31 ++++++++++++++++++++++++--- 1 file changed, 28 insertions(+), 3 deletions(-) diff --git a/web/components/issues/title-input.tsx b/web/components/issues/title-input.tsx index 2dd408fae4d..4a4057a6ac6 100644 --- a/web/components/issues/title-input.tsx +++ b/web/components/issues/title-input.tsx @@ -19,11 +19,10 @@ export type IssueTitleInputProps = { }; export const IssueTitleInput: FC = observer((props) => { - const { disabled, value, workspaceSlug, setIsSubmitting, issueId, issueOperations, projectId } = props; + const { disabled, value, workspaceSlug, isSubmitting, setIsSubmitting, issueId, issueOperations, projectId } = props; // states const [title, setTitle] = useState(""); // hooks - const debouncedValue = useDebounce(title, 1500); useEffect(() => { @@ -31,16 +30,41 @@ export const IssueTitleInput: FC = observer((props) => { }, [value]); useEffect(() => { + const textarea = document.querySelector("#title-input"); if (debouncedValue && debouncedValue !== value) { issueOperations.update(workspaceSlug, projectId, issueId, { name: debouncedValue }, false).finally(() => { - setTitle(debouncedValue.trim()); setIsSubmitting("saved"); + if (textarea && !textarea.matches(":focus")) { + const trimmedTitle = debouncedValue.trim(); + if (trimmedTitle !== title) setTitle(trimmedTitle); + } }); } // DO NOT Add more dependencies here. It will cause multiple requests to be sent. // eslint-disable-next-line react-hooks/exhaustive-deps }, [debouncedValue]); + useEffect(() => { + const handleBlur = () => { + const trimmedTitle = title.trim(); + if (trimmedTitle !== title && isSubmitting !== "submitting") { + setTitle(trimmedTitle); + setIsSubmitting("submitting"); + } + }; + + const textarea = document.querySelector("#title-input"); // You might need to change this selector according to your TextArea component + if (textarea) { + textarea.addEventListener("blur", handleBlur); + } + + return () => { + if (textarea) { + textarea.removeEventListener("blur", handleBlur); + } + }; + }, [title, isSubmitting, setIsSubmitting]); + const handleTitleChange = useCallback( (e: React.ChangeEvent) => { setIsSubmitting("submitting"); @@ -54,6 +78,7 @@ export const IssueTitleInput: FC = observer((props) => { return (