mirror of
https://github.com/ahmadk953/tasko.git
synced 2025-01-31 09:03:36 +00:00
94 lines
2.5 KiB
TypeScript
94 lines
2.5 KiB
TypeScript
"use client";
|
|
|
|
import { X } from "lucide-react";
|
|
import { toast } from "sonner";
|
|
import { ElementRef, useRef } from "react";
|
|
import { useRouter } from "next/navigation";
|
|
|
|
import {
|
|
Popover,
|
|
PopoverClose,
|
|
PopoverContent,
|
|
PopoverTrigger,
|
|
} from "@/components/ui/popover";
|
|
import { useAction } from "@/hooks/use-action";
|
|
import { createBoard } from "@/actions/create-board";
|
|
import { Button } from "@/components//ui/button";
|
|
import { useProModal } from "@/hooks/use-pro-modal";
|
|
|
|
import { FormInput } from "./form-input";
|
|
import { FormSubmit } from "./form-submit";
|
|
import { FormPicker } from "./form-picker";
|
|
|
|
interface FormPopoverProps {
|
|
children: React.ReactNode;
|
|
side?: "left" | "right" | "top" | "bottom";
|
|
align?: "center" | "start" | "end";
|
|
sideOffset?: number;
|
|
}
|
|
|
|
export const FormPopover = ({
|
|
children,
|
|
side = "bottom",
|
|
align,
|
|
sideOffset = 0,
|
|
}: FormPopoverProps) => {
|
|
const proModal = useProModal();
|
|
const router = useRouter();
|
|
const closeRef = useRef<ElementRef<"button">>(null);
|
|
|
|
const { execute, fieldErrors } = useAction(createBoard, {
|
|
onSuccess: (data) => {
|
|
toast.success("Board created");
|
|
closeRef.current?.click();
|
|
router.push(`/board/${data.id}`);
|
|
},
|
|
onError: (error) => {
|
|
toast.error(error);
|
|
proModal.onOpen();
|
|
},
|
|
});
|
|
|
|
const onSubmit = (formData: FormData) => {
|
|
const title = formData.get("title") as string;
|
|
const image = formData.get("image") as string;
|
|
|
|
execute({ title, image });
|
|
};
|
|
|
|
return (
|
|
<Popover>
|
|
<PopoverTrigger asChild>{children}</PopoverTrigger>
|
|
<PopoverContent
|
|
align={align}
|
|
className="w-80 pt-3"
|
|
side={side}
|
|
sideOffset={sideOffset}
|
|
>
|
|
<div className="text-sm font-medium text-center text-neutral-600 pb-4">
|
|
Create board
|
|
</div>
|
|
<PopoverClose ref={closeRef} asChild>
|
|
<Button
|
|
className="h-auto w-auto p-2 absolute top-2 right-2 text-neutral-600"
|
|
variant="ghost"
|
|
>
|
|
<X className="h-4 w-4" />
|
|
</Button>
|
|
</PopoverClose>
|
|
<form action={onSubmit} className="space-y-4">
|
|
<div className="space-y-4">
|
|
<FormPicker id="image" errors={fieldErrors} />
|
|
<FormInput
|
|
id="title"
|
|
label="Board Title"
|
|
type="text"
|
|
errors={fieldErrors}
|
|
/>
|
|
</div>
|
|
<FormSubmit className="w-full">Create</FormSubmit>
|
|
</form>
|
|
</PopoverContent>
|
|
</Popover>
|
|
);
|
|
};
|