mirror of
https://github.com/Dokploy/dokploy
synced 2025-06-26 18:27:59 +00:00
* refactor: add sidebar * chore: add deps * refactor: update sidebar * refactor: another layout * refactor: update variant * refactor: change layout * refactor: change variant * refactor: enhance sidebar navigation with active state management * feat: add project button to dashboard * Merge branch 'canary' into feat/add-sidebar * refactor: add loader * refactor: update destinations and refactor * refactor: ui refactor certificates * refactor: delete unused files * refactor: remove unused files and duplicate registry * refactor: update style registry * refactor: add new design registry * refactor: enhance git providers * refactor: remove duplicate files * refactor: update * refactor: update users * refactor: delete unused files * refactor: update profile * refactor: apply changes * refactor: update UI * refactor: enhance Docker monitoring UI layout * refactor: add theme toggle and language selection to user navigation (#1083) * refactor: remove unused files * feat: add filter to services * refactor: add active items * refactor: remove tab prop * refactor: remove unused files * refactor: remove duplicated files * refactor: remove unused files * refactor: remove duplicate files * refactor: remove unused files * refactor: delete unused files * refactor: remove unsued files * refactor: delete unused files * refactor: lint * refactor: remove unused secuirty * refactor: delete unused files * refactor: delete unused files * remove imports * refactor: add update button * refactor: delete unused files * refactor: remove unused code * refactor: remove unused files * refactor: update login page * refactor: update login UI * refactor: update ui reset password * refactor: add justify end * feat: add suscriptions * feat: add sheet * feat: add logs for postgres * feat: add logs for all databases * feat: add server logs with drawer logs * refactor: remove unused files * refactor: add refetch when closing * refactor: fix linter * chore: bump node-20 * revert * refactor: fix conflicts * refactor: update * refactor: add missing deps * refactor: delete duplicate files * refactor: delete unsued files * chore: lint * refactor: remove unsued file * refactor: add refetch * refactor: remove duplicated files * refactor: delete unused files * refactor: update setup onboarding * refactor: add breadcrumb * refactor: apply updates * refactor: add faker * refactor: use 0 in validation * refactor: show correct state * refactor: update --------- Co-authored-by: vishalkadam47 <vishal@jeevops.com> Co-authored-by: Vishal kadam <107353260+vishalkadam47@users.noreply.github.com>
205 lines
6.0 KiB
TypeScript
205 lines
6.0 KiB
TypeScript
import { ShowBuildChooseForm } from "@/components/dashboard/application/build/show";
|
|
import { ShowProviderForm } from "@/components/dashboard/application/general/generic/show";
|
|
import { DialogAction } from "@/components/shared/dialog-action";
|
|
import { Button } from "@/components/ui/button";
|
|
import { Card, CardContent, CardHeader, CardTitle } from "@/components/ui/card";
|
|
import { Switch } from "@/components/ui/switch";
|
|
import { api } from "@/utils/api";
|
|
import { Ban, CheckCircle2, Hammer, RefreshCcw, Terminal } from "lucide-react";
|
|
import { useRouter } from "next/router";
|
|
import React from "react";
|
|
import { toast } from "sonner";
|
|
import { DockerTerminalModal } from "../../settings/web-server/docker-terminal-modal";
|
|
interface Props {
|
|
applicationId: string;
|
|
}
|
|
|
|
export const ShowGeneralApplication = ({ applicationId }: Props) => {
|
|
const router = useRouter();
|
|
const { data, refetch } = api.application.one.useQuery(
|
|
{
|
|
applicationId,
|
|
},
|
|
{ enabled: !!applicationId },
|
|
);
|
|
const { mutateAsync: update } = api.application.update.useMutation();
|
|
const { mutateAsync: start, isLoading: isStarting } =
|
|
api.application.start.useMutation();
|
|
const { mutateAsync: stop, isLoading: isStopping } =
|
|
api.application.stop.useMutation();
|
|
|
|
const { mutateAsync: deploy, isLoading: isDeploying } =
|
|
api.application.deploy.useMutation();
|
|
|
|
const { mutateAsync: reload, isLoading: isReloading } =
|
|
api.application.reload.useMutation();
|
|
|
|
const { mutateAsync: redeploy } = api.application.redeploy.useMutation();
|
|
|
|
return (
|
|
<>
|
|
<Card className="bg-background">
|
|
<CardHeader>
|
|
<CardTitle className="text-xl">Deploy Settings</CardTitle>
|
|
</CardHeader>
|
|
<CardContent className="flex flex-row gap-4 flex-wrap">
|
|
<DialogAction
|
|
title="Deploy Application"
|
|
description="Are you sure you want to deploy this application?"
|
|
type="default"
|
|
onClick={async () => {
|
|
await deploy({
|
|
applicationId: applicationId,
|
|
})
|
|
.then(() => {
|
|
toast.success("Application deployed successfully");
|
|
refetch();
|
|
router.push(
|
|
`/dashboard/project/${data?.projectId}/services/application/${applicationId}?tab=deployments`,
|
|
);
|
|
})
|
|
.catch(() => {
|
|
toast.error("Error deploying application");
|
|
});
|
|
}}
|
|
>
|
|
<Button
|
|
variant="default"
|
|
isLoading={data?.applicationStatus === "running"}
|
|
>
|
|
Deploy
|
|
</Button>
|
|
</DialogAction>
|
|
<DialogAction
|
|
title="Reload Application"
|
|
description="Are you sure you want to reload this application?"
|
|
type="default"
|
|
onClick={async () => {
|
|
await reload({
|
|
applicationId: applicationId,
|
|
appName: data?.appName || "",
|
|
})
|
|
.then(() => {
|
|
toast.success("Application reloaded successfully");
|
|
refetch();
|
|
})
|
|
.catch(() => {
|
|
toast.error("Error reloading application");
|
|
});
|
|
}}
|
|
>
|
|
<Button variant="secondary" isLoading={isReloading}>
|
|
Reload
|
|
<RefreshCcw className="size-4" />
|
|
</Button>
|
|
</DialogAction>
|
|
<DialogAction
|
|
title="Rebuild Application"
|
|
description="Are you sure you want to rebuild this application?"
|
|
type="default"
|
|
onClick={async () => {
|
|
await redeploy({
|
|
applicationId: applicationId,
|
|
})
|
|
.then(() => {
|
|
toast.success("Application rebuilt successfully");
|
|
refetch();
|
|
})
|
|
.catch(() => {
|
|
toast.error("Error rebuilding application");
|
|
});
|
|
}}
|
|
>
|
|
<Button
|
|
variant="secondary"
|
|
isLoading={data?.applicationStatus === "running"}
|
|
>
|
|
Rebuild
|
|
<Hammer className="size-4" />
|
|
</Button>
|
|
</DialogAction>
|
|
|
|
{data?.applicationStatus === "idle" ? (
|
|
<DialogAction
|
|
title="Start Application"
|
|
description="Are you sure you want to start this application?"
|
|
type="default"
|
|
onClick={async () => {
|
|
await start({
|
|
applicationId: applicationId,
|
|
})
|
|
.then(() => {
|
|
toast.success("Application started successfully");
|
|
refetch();
|
|
})
|
|
.catch(() => {
|
|
toast.error("Error starting application");
|
|
});
|
|
}}
|
|
>
|
|
<Button variant="secondary" isLoading={isStarting}>
|
|
Start
|
|
<CheckCircle2 className="size-4" />
|
|
</Button>
|
|
</DialogAction>
|
|
) : (
|
|
<DialogAction
|
|
title="Stop Application"
|
|
description="Are you sure you want to stop this application?"
|
|
onClick={async () => {
|
|
await stop({
|
|
applicationId: applicationId,
|
|
})
|
|
.then(() => {
|
|
toast.success("Application stopped successfully");
|
|
refetch();
|
|
})
|
|
.catch(() => {
|
|
toast.error("Error stopping application");
|
|
});
|
|
}}
|
|
>
|
|
<Button variant="destructive" isLoading={isStopping}>
|
|
Stop
|
|
<Ban className="size-4" />
|
|
</Button>
|
|
</DialogAction>
|
|
)}
|
|
<DockerTerminalModal
|
|
appName={data?.appName || ""}
|
|
serverId={data?.serverId || ""}
|
|
>
|
|
<Button variant="outline">
|
|
<Terminal />
|
|
Open Terminal
|
|
</Button>
|
|
</DockerTerminalModal>
|
|
<div className="flex flex-row items-center gap-2 rounded-md px-4 py-2 border">
|
|
<span className="text-sm font-medium">Autodeploy</span>
|
|
<Switch
|
|
aria-label="Toggle italic"
|
|
checked={data?.autoDeploy || false}
|
|
onCheckedChange={async (enabled) => {
|
|
await update({
|
|
applicationId,
|
|
autoDeploy: enabled,
|
|
})
|
|
.then(async () => {
|
|
toast.success("Auto Deploy Updated");
|
|
await refetch();
|
|
})
|
|
.catch(() => {
|
|
toast.error("Error updating Auto Deploy");
|
|
});
|
|
}}
|
|
className="flex flex-row gap-2 items-center"
|
|
/>
|
|
</div>
|
|
</CardContent>
|
|
</Card>
|
|
<ShowProviderForm applicationId={applicationId} />
|
|
<ShowBuildChooseForm applicationId={applicationId} />
|
|
</>
|
|
);
|
|
};
|