mirror of
https://github.com/Dokploy/dokploy.git
synced 2026-07-03 04:55:23 +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>
58 lines
1.3 KiB
TypeScript
58 lines
1.3 KiB
TypeScript
import { AlertCircle, AlertTriangle, CheckCircle2, Info } from "lucide-react";
|
|
import { cn } from "@/lib/utils";
|
|
|
|
interface Props extends React.ComponentPropsWithoutRef<"div"> {
|
|
icon?: React.ReactNode;
|
|
type?: "info" | "success" | "warning" | "error";
|
|
}
|
|
|
|
const iconMap = {
|
|
info: {
|
|
className: "bg-blue-50 dark:bg-blue-950 text-blue-600 dark:text-blue-400",
|
|
icon: Info,
|
|
},
|
|
success: {
|
|
className:
|
|
"bg-green-50 dark:bg-green-950 text-green-600 dark:text-green-400",
|
|
icon: CheckCircle2,
|
|
},
|
|
warning: {
|
|
className:
|
|
"bg-orange-50 dark:bg-orange-950 text-orange-600 dark:text-orange-400",
|
|
icon: AlertCircle,
|
|
},
|
|
error: {
|
|
className: "bg-red-50 dark:bg-red-950 text-red-600 dark:text-red-400",
|
|
icon: AlertTriangle,
|
|
},
|
|
};
|
|
|
|
export function AlertBlock({
|
|
type = "info",
|
|
icon,
|
|
children,
|
|
className,
|
|
...props
|
|
}: Props) {
|
|
const { className: iconClassName, icon: Icon } = iconMap[type];
|
|
return (
|
|
<div
|
|
{...props}
|
|
className={cn(
|
|
"flex items-start flex-row gap-4 rounded-lg p-2",
|
|
iconClassName,
|
|
className,
|
|
)}
|
|
>
|
|
<div className="shrink-0 mt-0.5">
|
|
{icon || <Icon className="text-current" />}
|
|
</div>
|
|
<div className="flex-1 min-w-0">
|
|
<span className="text-sm text-current wrap-break-word overflow-wrap-anywhere whitespace-pre-wrap">
|
|
{children}
|
|
</span>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|