/* ┌──────────────────────────────────────────────────────────────────────────────┐ │ @author: Davidson Gomes │ │ @file: /app/agents/dialogs/FolderDialog.tsx │ │ Developed by: Davidson Gomes │ │ Creation date: May 13, 2025 │ │ Contact: contato@evolution-api.com │ ├──────────────────────────────────────────────────────────────────────────────┤ │ @copyright © Evolution API 2025. All rights reserved. │ │ Licensed under the Apache License, Version 2.0 │ │ │ │ You may not use this file except in compliance with the License. │ │ You may obtain a copy of the License at │ │ │ │ http://www.apache.org/licenses/LICENSE-2.0 │ │ │ │ Unless required by applicable law or agreed to in writing, software │ │ distributed under the License is distributed on an "AS IS" BASIS, │ │ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. │ │ See the License for the specific language governing permissions and │ │ limitations under the License. │ ├──────────────────────────────────────────────────────────────────────────────┤ │ @important │ │ For any future changes to the code in this file, it is recommended to │ │ include, together with the modification, the information of the developer │ │ who changed it and the date of modification. │ └──────────────────────────────────────────────────────────────────────────────┘ */ "use client"; import { Button } from "@/components/ui/button"; import { Dialog, DialogContent, DialogDescription, DialogFooter, DialogHeader, DialogTitle, } from "@/components/ui/dialog"; import { Input } from "@/components/ui/input"; import { Label } from "@/components/ui/label"; import { Textarea } from "@/components/ui/textarea"; import { useState, useEffect } from "react"; interface Folder { id: string; name: string; description: string; } interface FolderDialogProps { open: boolean; onOpenChange: (open: boolean) => void; onSave: (folder: { name: string; description: string }) => Promise; editingFolder: Folder | null; isLoading?: boolean; } export function FolderDialog({ open, onOpenChange, onSave, editingFolder, isLoading = false, }: FolderDialogProps) { const [folder, setFolder] = useState<{ name: string; description: string; }>({ name: "", description: "", }); useEffect(() => { if (editingFolder) { setFolder({ name: editingFolder.name, description: editingFolder.description, }); } else { setFolder({ name: "", description: "", }); } }, [editingFolder, open]); const handleSave = async () => { await onSave(folder); }; return ( {editingFolder ? "Edit Folder" : "New Folder"} {editingFolder ? "Update the existing folder information" : "Fill in the information to create a new folder"}
setFolder({ ...folder, name: e.target.value }) } className="bg-[#222] border-[#444] text-white" />