mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-07-05 14:05:30 +02:00
* feat: update dependencies and enhance UI components in Dokploy - Updated various package versions in pnpm-lock.yaml to improve compatibility and performance, including React and Tailwind CSS. - Modified components.json to change the styling to "radix-nova" and added new properties for icon library and menu color. - Refactored multiple components to use updated class names for better styling consistency and responsiveness. - Removed unused Radix UI components from package.json to streamline dependencies. - Adjusted layout and styling in several dashboard components for improved user experience and visual appeal. - Enhanced tooltip and form item components for better accessibility and usability. * refactor: enhance UI components in HandleCertificate and SidebarLogo - Updated the HandleCertificate component to improve dialog content height and textarea styling for better usability. - Adjusted the SidebarLogo component layout to enhance alignment and spacing, ensuring a more consistent appearance across the sidebar. - Implemented responsive design adjustments to textarea elements, preventing overflow and improving user experience. * refactor: improve UI consistency and styling across dashboard components - Updated Card components in ShowDeployments, ShowSchedules, and ShowVolumeBackups to remove unnecessary border styles for a cleaner look. - Enhanced TabsList components in ShowProviderForm and ShowProviderFormCompose by adding a variant for improved visual distinction. - Adjusted spacing in AdvancedEnvironmentSelector for better layout and readability. - Removed redundant border classes in Service component for a more streamlined design. * [autofix.ci] apply automated fixes * chore: update package dependencies and refactor email rendering - Upgraded React and React DOM to version 19.2.7 across multiple packages for improved performance and compatibility. - Updated TSX to version 4.22.4 in various package.json files. - Refactored email rendering from `renderAsync` to `render` in notification utilities and email templates for consistency. - Adjusted Tailwind configuration usage in email templates to utilize a centralized configuration file. These changes enhance the overall stability and maintainability of the codebase. * refactor: update badge variants across dashboard components - Changed badge variant from "outline-solid" to "outline" in multiple components including columns, show-domains, and various deployment tables for consistency in styling. - Updated button variants in billing and project templates to align with the new badge styling. - Enhanced input components to support password generation and error messaging, improving user experience. These changes streamline the UI and ensure a cohesive design across the application. * refactor: clean up calendar component imports and structure - Removed redundant imports of icons from lucide-react and streamlined the import statements for better readability. - Adjusted the placement of type imports to enhance code organization. These changes improve the maintainability and clarity of the calendar component. * [autofix.ci] apply automated fixes --------- Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
117 lines
3.1 KiB
TypeScript
117 lines
3.1 KiB
TypeScript
import { Loader2, Puzzle, RefreshCw } from "lucide-react";
|
|
import { useEffect, useState } from "react";
|
|
import { toast } from "sonner";
|
|
import { AlertBlock } from "@/components/shared/alert-block";
|
|
import { CodeEditor } from "@/components/shared/code-editor";
|
|
import { Button } from "@/components/ui/button";
|
|
import {
|
|
Dialog,
|
|
DialogContent,
|
|
DialogDescription,
|
|
DialogHeader,
|
|
DialogTitle,
|
|
DialogTrigger,
|
|
} from "@/components/ui/dialog";
|
|
import { api } from "@/utils/api";
|
|
|
|
interface Props {
|
|
composeId: string;
|
|
}
|
|
|
|
export const ShowConvertedCompose = ({ composeId }: Props) => {
|
|
const [isOpen, setIsOpen] = useState(false);
|
|
const {
|
|
data: compose,
|
|
error,
|
|
isError,
|
|
refetch,
|
|
} = api.compose.getConvertedCompose.useQuery(
|
|
{ composeId },
|
|
{
|
|
retry: false,
|
|
},
|
|
);
|
|
|
|
const { mutateAsync, isPending } = api.compose.fetchSourceType.useMutation();
|
|
|
|
useEffect(() => {
|
|
if (isOpen) {
|
|
mutateAsync({ composeId })
|
|
.then(() => {
|
|
refetch();
|
|
})
|
|
.catch(() => {});
|
|
}
|
|
}, [isOpen]);
|
|
|
|
return (
|
|
<Dialog open={isOpen} onOpenChange={setIsOpen}>
|
|
<DialogTrigger asChild>
|
|
<Button className="max-lg:w-full" variant="outline">
|
|
<Puzzle className="h-4 w-4" />
|
|
Preview Compose
|
|
</Button>
|
|
</DialogTrigger>
|
|
<DialogContent className="sm:max-w-6xl max-h-200">
|
|
<DialogHeader>
|
|
<DialogTitle>Converted Compose</DialogTitle>
|
|
<DialogDescription>
|
|
Preview your docker-compose file with added domains. Note: At least
|
|
one domain must be specified for this conversion to take effect.
|
|
</DialogDescription>
|
|
</DialogHeader>
|
|
{isError && <AlertBlock type="error">{error?.message}</AlertBlock>}
|
|
|
|
<AlertBlock type="info" className="mb-4">
|
|
Preview your docker-compose file with added domains. Note: At least
|
|
one domain must be specified for this conversion to take effect.
|
|
</AlertBlock>
|
|
{isPending ? (
|
|
<div className="flex flex-row items-center justify-center min-h-100 border p-4 rounded-md">
|
|
<Loader2 className="h-8 w-8 text-muted-foreground mb-2 animate-spin" />
|
|
</div>
|
|
) : compose?.length === 5 ? (
|
|
<div className="border p-4 rounded-md flex flex-col items-center justify-center min-h-100">
|
|
<Puzzle className="h-8 w-8 text-muted-foreground mb-2" />
|
|
<span className="text-muted-foreground">
|
|
No converted compose data available.
|
|
</span>
|
|
</div>
|
|
) : (
|
|
<>
|
|
<div className="flex flex-row gap-2 justify-end my-4">
|
|
<Button
|
|
variant="secondary"
|
|
isLoading={isPending}
|
|
onClick={() => {
|
|
mutateAsync({ composeId })
|
|
.then(() => {
|
|
refetch();
|
|
toast.success("Fetched source type");
|
|
})
|
|
.catch((err) => {
|
|
toast.error("Error fetching source type", {
|
|
description: err.message,
|
|
});
|
|
});
|
|
}}
|
|
>
|
|
Refresh <RefreshCw className="ml-2 h-4 w-4" />
|
|
</Button>
|
|
</div>
|
|
|
|
<pre>
|
|
<CodeEditor
|
|
value={compose || ""}
|
|
language="yaml"
|
|
readOnly
|
|
height="50rem"
|
|
/>
|
|
</pre>
|
|
</>
|
|
)}
|
|
</DialogContent>
|
|
</Dialog>
|
|
);
|
|
};
|