mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-06-15 20:25:23 +02:00
51 lines
1.2 KiB
TypeScript
51 lines
1.2 KiB
TypeScript
import { Label } from "@/components/ui/label";
|
|
import { Switch } from "@/components/ui/switch";
|
|
import { api } from "@/utils/api";
|
|
import { toast } from "sonner";
|
|
|
|
interface Props {
|
|
serverId?: string;
|
|
}
|
|
export const ToggleDockerCleanup = ({ serverId }: Props) => {
|
|
const { data, refetch } = api.user.get.useQuery(undefined, {
|
|
enabled: !serverId,
|
|
});
|
|
|
|
const { data: server, refetch: refetchServer } = api.server.one.useQuery(
|
|
{
|
|
serverId: serverId || "",
|
|
},
|
|
{
|
|
enabled: !!serverId,
|
|
},
|
|
);
|
|
|
|
const enabled = data?.user.enableDockerCleanup || server?.enableDockerCleanup;
|
|
|
|
const { mutateAsync } = api.settings.updateDockerCleanup.useMutation();
|
|
|
|
const handleToggle = async (checked: boolean) => {
|
|
try {
|
|
await mutateAsync({
|
|
enableDockerCleanup: checked,
|
|
serverId: serverId,
|
|
});
|
|
if (serverId) {
|
|
await refetchServer();
|
|
} else {
|
|
await refetch();
|
|
}
|
|
toast.success("Docker Cleanup updated");
|
|
} catch (error) {
|
|
toast.error("Docker Cleanup Error");
|
|
}
|
|
};
|
|
|
|
return (
|
|
<div className="flex items-center gap-4">
|
|
<Switch checked={!!enabled} onCheckedChange={handleToggle} />
|
|
<Label className="text-primary">Daily Docker Cleanup</Label>
|
|
</div>
|
|
);
|
|
};
|