"use client";
import { useState } from "react";
import { useRouter } from "next/navigation";
import { AdminDialog } from "@/components/ui/admin-dialog";
import { createAccount, updateAccount, toggleAccountActive } from "./actions";
type AccountRow = {
id: string;
code: string;
name: string;
description: string | null;
isActive: boolean;
};
function AccountFormFields({ account }: { account?: AccountRow }) {
return (
);
}
export function AddAccountButton() {
const router = useRouter();
const [open, setOpen] = useState(false);
const [pending, setPending] = useState(false);
const [error, setError] = useState("");
async function handleSubmit(e: React.FormEvent) {
e.preventDefault();
setPending(true);
setError("");
const result = await createAccount(new FormData(e.currentTarget));
if ("error" in result) { setError(result.error); setPending(false); }
else { setPending(false); setOpen(false); router.refresh(); }
}
return (
<>
setOpen(false)}>
>
);
}
export function EditAccountButton({ account }: { account: AccountRow }) {
const router = useRouter();
const [open, setOpen] = useState(false);
const [pending, setPending] = useState(false);
const [toggling, setToggling] = useState(false);
const [error, setError] = useState("");
async function handleSubmit(e: React.FormEvent) {
e.preventDefault();
setPending(true);
setError("");
const fd = new FormData(e.currentTarget);
fd.set("id", account.id);
const result = await updateAccount(fd);
if ("error" in result) { setError(result.error); setPending(false); }
else { setPending(false); setOpen(false); router.refresh(); }
}
async function handleToggle() {
setToggling(true);
await toggleAccountActive(account.id);
router.refresh();
setToggling(false);
}
return (
<>
setOpen(false)}>
>
);
}