forked from github/plane
fix: project select not working on the create issue modal (#1608)
This commit is contained in:
parent
fdb7da4d45
commit
7669ee8755
@ -96,13 +96,7 @@ export const IssueDescriptionForm: FC<IssueDetailsProps> = ({
|
|||||||
setCharacterLimit(false);
|
setCharacterLimit(false);
|
||||||
|
|
||||||
setIsSubmitting(true);
|
setIsSubmitting(true);
|
||||||
handleSubmit(handleDescriptionFormSubmit)()
|
handleSubmit(handleDescriptionFormSubmit)().finally(() => setIsSubmitting(false));
|
||||||
.then(() => {
|
|
||||||
setIsSubmitting(false);
|
|
||||||
})
|
|
||||||
.catch(() => {
|
|
||||||
setIsSubmitting(false);
|
|
||||||
});
|
|
||||||
}}
|
}}
|
||||||
required={true}
|
required={true}
|
||||||
className="min-h-10 block w-full resize-none overflow-hidden rounded border-none bg-transparent px-3 py-2 text-xl outline-none ring-0 focus:ring-1 focus:ring-custom-primary"
|
className="min-h-10 block w-full resize-none overflow-hidden rounded border-none bg-transparent px-3 py-2 text-xl outline-none ring-0 focus:ring-1 focus:ring-custom-primary"
|
||||||
@ -110,7 +104,7 @@ export const IssueDescriptionForm: FC<IssueDetailsProps> = ({
|
|||||||
disabled={!isAllowed}
|
disabled={!isAllowed}
|
||||||
/>
|
/>
|
||||||
{characterLimit && (
|
{characterLimit && (
|
||||||
<div className="pointer-events-none absolute bottom-0 right-0 z-[2] rounded bg-custom-background-80 p-1 text-xs">
|
<div className="pointer-events-none absolute bottom-1 right-1 z-[2] rounded bg-custom-background-100 text-custom-text-200 p-0.5 text-xs">
|
||||||
<span
|
<span
|
||||||
className={`${
|
className={`${
|
||||||
watch("name").length === 0 || watch("name").length > 255 ? "text-red-500" : ""
|
watch("name").length === 0 || watch("name").length > 255 ? "text-red-500" : ""
|
||||||
@ -123,52 +117,47 @@ export const IssueDescriptionForm: FC<IssueDetailsProps> = ({
|
|||||||
)}
|
)}
|
||||||
</div>
|
</div>
|
||||||
<span>{errors.name ? errors.name.message : null}</span>
|
<span>{errors.name ? errors.name.message : null}</span>
|
||||||
<Controller
|
<div className="relative">
|
||||||
name="description"
|
<Controller
|
||||||
control={control}
|
name="description"
|
||||||
render={({ field: { value } }) => {
|
control={control}
|
||||||
if (!value && !watch("description_html")) return <></>;
|
render={({ field: { value } }) => {
|
||||||
|
if (!value && !watch("description_html")) return <></>;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<RemirrorRichTextEditor
|
<RemirrorRichTextEditor
|
||||||
value={
|
value={
|
||||||
!value ||
|
!value ||
|
||||||
value === "" ||
|
value === "" ||
|
||||||
(typeof value === "object" && Object.keys(value).length === 0)
|
(typeof value === "object" && Object.keys(value).length === 0)
|
||||||
? watch("description_html")
|
? watch("description_html")
|
||||||
: value
|
: value
|
||||||
}
|
}
|
||||||
onJSONChange={(jsonValue) => {
|
onJSONChange={(jsonValue) => {
|
||||||
setShowAlert(true);
|
setShowAlert(true);
|
||||||
setValue("description", jsonValue);
|
setValue("description", jsonValue);
|
||||||
}}
|
}}
|
||||||
onHTMLChange={(htmlValue) => {
|
onHTMLChange={(htmlValue) => {
|
||||||
setShowAlert(true);
|
setShowAlert(true);
|
||||||
setValue("description_html", htmlValue);
|
setValue("description_html", htmlValue);
|
||||||
}}
|
}}
|
||||||
onBlur={() => {
|
onBlur={() => {
|
||||||
setIsSubmitting(true);
|
setIsSubmitting(true);
|
||||||
handleSubmit(handleDescriptionFormSubmit)()
|
handleSubmit(handleDescriptionFormSubmit)()
|
||||||
.then(() => {
|
.then(() => setShowAlert(false))
|
||||||
setIsSubmitting(false);
|
.finally(() => setIsSubmitting(false));
|
||||||
setShowAlert(false);
|
}}
|
||||||
})
|
placeholder="Description"
|
||||||
.catch(() => {
|
editable={isAllowed}
|
||||||
setIsSubmitting(false);
|
/>
|
||||||
});
|
);
|
||||||
}}
|
}}
|
||||||
placeholder="Description"
|
/>
|
||||||
editable={isAllowed}
|
{isSubmitting && (
|
||||||
/>
|
<div className="absolute bottom-1 right-1 text-xs text-custom-text-200 bg-custom-background-100 p-3 z-10">
|
||||||
);
|
Saving...
|
||||||
}}
|
</div>
|
||||||
/>
|
)}
|
||||||
<div
|
|
||||||
className={`absolute -bottom-8 right-0 text-sm text-custom-text-200 ${
|
|
||||||
isSubmitting ? "block" : "hidden"
|
|
||||||
}`}
|
|
||||||
>
|
|
||||||
Saving...
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
@ -261,8 +261,10 @@ export const IssueForm: FC<IssueFormProps> = ({
|
|||||||
render={({ field: { value, onChange } }) => (
|
render={({ field: { value, onChange } }) => (
|
||||||
<IssueProjectSelect
|
<IssueProjectSelect
|
||||||
value={value}
|
value={value}
|
||||||
onChange={onChange}
|
onChange={(val: string) => {
|
||||||
setActiveProject={setActiveProject}
|
onChange(val);
|
||||||
|
setActiveProject(val);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
/>
|
/>
|
||||||
|
@ -95,9 +95,9 @@ export const CreateUpdateIssueModal: React.FC<IssuesModalProps> = ({
|
|||||||
};
|
};
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (projects && projects.length > 0)
|
if (projects && projects.length > 0 && !activeProject)
|
||||||
setActiveProject(projects?.find((p) => p.id === projectId)?.id ?? projects?.[0].id ?? null);
|
setActiveProject(projects?.find((p) => p.id === projectId)?.id ?? projects?.[0].id ?? null);
|
||||||
}, [projectId, projects]);
|
}, [activeProject, projectId, projects]);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
const handleKeyDown = (e: KeyboardEvent) => {
|
const handleKeyDown = (e: KeyboardEvent) => {
|
||||||
|
@ -8,14 +8,9 @@ import { ClipboardDocumentListIcon } from "@heroicons/react/24/outline";
|
|||||||
export interface IssueProjectSelectProps {
|
export interface IssueProjectSelectProps {
|
||||||
value: string;
|
value: string;
|
||||||
onChange: (value: string) => void;
|
onChange: (value: string) => void;
|
||||||
setActiveProject: React.Dispatch<React.SetStateAction<string | null>>;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export const IssueProjectSelect: React.FC<IssueProjectSelectProps> = ({
|
export const IssueProjectSelect: React.FC<IssueProjectSelectProps> = ({ value, onChange }) => {
|
||||||
value,
|
|
||||||
onChange,
|
|
||||||
setActiveProject,
|
|
||||||
}) => {
|
|
||||||
const { projects } = useProjects();
|
const { projects } = useProjects();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
@ -29,10 +24,7 @@ export const IssueProjectSelect: React.FC<IssueProjectSelectProps> = ({
|
|||||||
</span>
|
</span>
|
||||||
</>
|
</>
|
||||||
}
|
}
|
||||||
onChange={(val: string) => {
|
onChange={(val: string) => onChange(val)}
|
||||||
onChange(val);
|
|
||||||
setActiveProject(val);
|
|
||||||
}}
|
|
||||||
noChevron
|
noChevron
|
||||||
>
|
>
|
||||||
{projects ? (
|
{projects ? (
|
||||||
|
Loading…
Reference in New Issue
Block a user