"use client"; import { Button } from "@/shared/components/ui/button"; import { Form, FormControl, FormField, FormItem, FormLabel, FormMessage, } from "@/shared/components/ui/form"; import { Input } from "@/shared/components/ui/input"; import { Textarea } from "@/shared/components/ui/textarea"; import { Switch } from "@/shared/components/ui/switch"; import { zodResolver } from "@hookform/resolvers/zod"; import { useForm } from "react-hook-form"; import { CredentialFormValues, credentialSchema, } from "../../../../../shared/schemas/credential"; import { Credential } from "@/shared/types/credential"; import { PlusCircle, X } from "lucide-react"; interface CredentialFormProps { defaultValues?: Partial; onSubmitAction: (data: CredentialFormValues) => void; isSubmitting?: boolean; onCancelAction?: () => void; } export function CredentialForm({ defaultValues, onSubmitAction, isSubmitting, onCancelAction, }: CredentialFormProps) { const form = useForm({ resolver: zodResolver(credentialSchema), defaultValues: { id: defaultValues?.id || "", name: defaultValues?.name || "", description: defaultValues?.description || "", credential_type: defaultValues?.credential_type || "", credential_metadata: defaultValues?.credential_metadata || { environment: "", version: "", }, is_default: defaultValues?.is_default ?? false, is_active: defaultValues?.is_active ?? true, created_by: defaultValues?.created_by || "", updated_by: defaultValues?.updated_by || "", created_at: defaultValues?.created_at || "", updated_at: defaultValues?.updated_at || "", last_used_at: defaultValues?.last_used_at || "", last_used_by: defaultValues?.last_used_by || "", sensitive_data: defaultValues?.decrypted_data || {}, // 🆕 This line }, }); return (
( Nama Kredensial )} /> ( Deskripsi