diff --git a/apps/dokploy/__test__/drop/drop.test.ts b/apps/dokploy/__test__/drop/drop.test.ts index 3945e6a0c..301278dc3 100644 --- a/apps/dokploy/__test__/drop/drop.test.ts +++ b/apps/dokploy/__test__/drop/drop.test.ts @@ -25,6 +25,7 @@ if (typeof window === "undefined") { } const baseApp: ApplicationNested = { + railpackVersion: "0.2.2", applicationId: "", herokuVersion: "", giteaBranch: "", diff --git a/apps/dokploy/__test__/traefik/traefik.test.ts b/apps/dokploy/__test__/traefik/traefik.test.ts index 2bea75fb7..8d9f78aba 100644 --- a/apps/dokploy/__test__/traefik/traefik.test.ts +++ b/apps/dokploy/__test__/traefik/traefik.test.ts @@ -3,6 +3,7 @@ import { createRouterConfig } from "@dokploy/server"; import { expect, test } from "vitest"; const baseApp: ApplicationNested = { + railpackVersion: "0.2.2", rollbackActive: false, applicationId: "", herokuVersion: "", diff --git a/apps/dokploy/components/dashboard/application/build/show.tsx b/apps/dokploy/components/dashboard/application/build/show.tsx index 291026d4f..1a0ed386d 100644 --- a/apps/dokploy/components/dashboard/application/build/show.tsx +++ b/apps/dokploy/components/dashboard/application/build/show.tsx @@ -1,3 +1,9 @@ +import { zodResolver } from "@hookform/resolvers/zod"; +import { Cog } from "lucide-react"; +import { useEffect } from "react"; +import { useForm } from "react-hook-form"; +import { toast } from "sonner"; +import { z } from "zod"; import { AlertBlock } from "@/components/shared/alert-block"; import { Badge } from "@/components/ui/badge"; import { Button } from "@/components/ui/button"; @@ -15,12 +21,6 @@ import { import { Input } from "@/components/ui/input"; import { RadioGroup, RadioGroupItem } from "@/components/ui/radio-group"; import { api } from "@/utils/api"; -import { zodResolver } from "@hookform/resolvers/zod"; -import { Cog } from "lucide-react"; -import { useEffect } from "react"; -import { useForm } from "react-hook-form"; -import { toast } from "sonner"; -import { z } from "zod"; export enum BuildType { dockerfile = "dockerfile", @@ -65,6 +65,7 @@ const mySchema = z.discriminatedUnion("buildType", [ }), z.object({ buildType: z.literal(BuildType.railpack), + railpackVersion: z.string().nullable().default("0.2.2"), }), z.object({ buildType: z.literal(BuildType.static), @@ -86,6 +87,7 @@ interface ApplicationData { herokuVersion?: string | null; publishDirectory?: string | null; isStaticSpa?: boolean | null; + railpackVersion?: string | null | undefined; } function isValidBuildType(value: string): value is BuildType { @@ -123,6 +125,7 @@ const resetData = (data: ApplicationData): AddTemplate => { case BuildType.railpack: return { buildType: BuildType.railpack, + railpackVersion: data.railpackVersion || null, }; default: { const buildType = data.buildType as BuildType; @@ -181,6 +184,10 @@ export const ShowBuildChooseForm = ({ applicationId }: Props) => { : null, isStaticSpa: data.buildType === BuildType.static ? data.isStaticSpa : null, + railpackVersion: + data.buildType === BuildType.railpack + ? data.railpackVersion || "0.2.2" + : null, }) .then(async () => { toast.success("Build type saved"); @@ -395,6 +402,25 @@ export const ShowBuildChooseForm = ({ applicationId }: Props) => { )} /> )} + {buildType === BuildType.railpack && ( + ( + + Railpack Version + + + + + + )} + /> + )}