mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-01-31 06:42:03 +00:00
- Added a new PlanningMode feature to manage default planning strategies for features. - Updated the FeatureDefaultsSection to include a dropdown for selecting the default planning mode. - Enhanced AddFeatureDialog and EditFeatureDialog to support planning mode selection and state management. - Introduced PlanningModeSelector component for better user interaction with planning modes. - Updated app state management to include default planning mode and related specifications. - Refactored various UI components to ensure compatibility with new planning mode features.
72 lines
2.3 KiB
TypeScript
72 lines
2.3 KiB
TypeScript
"use client"
|
|
|
|
import * as React from "react"
|
|
import * as TooltipPrimitive from "@radix-ui/react-tooltip"
|
|
|
|
import { cn } from "@/lib/utils"
|
|
|
|
// Type-safe wrappers for Radix UI primitives (React 19 compatibility)
|
|
const TooltipTriggerPrimitive = TooltipPrimitive.Trigger as React.ForwardRefExoticComponent<
|
|
React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Trigger> & {
|
|
children?: React.ReactNode;
|
|
asChild?: boolean;
|
|
} & React.RefAttributes<HTMLButtonElement>
|
|
>;
|
|
|
|
const TooltipContentPrimitive = TooltipPrimitive.Content as React.ForwardRefExoticComponent<
|
|
React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content> & {
|
|
className?: string;
|
|
} & React.RefAttributes<HTMLDivElement>
|
|
>;
|
|
|
|
const TooltipProvider = TooltipPrimitive.Provider
|
|
|
|
const Tooltip = TooltipPrimitive.Root
|
|
|
|
function TooltipTrigger({
|
|
children,
|
|
asChild,
|
|
...props
|
|
}: React.ComponentProps<typeof TooltipPrimitive.Trigger> & {
|
|
children?: React.ReactNode;
|
|
asChild?: boolean;
|
|
}) {
|
|
return (
|
|
<TooltipTriggerPrimitive asChild={asChild} {...props}>
|
|
{children}
|
|
</TooltipTriggerPrimitive>
|
|
)
|
|
}
|
|
|
|
const TooltipContent = React.forwardRef<
|
|
React.ElementRef<typeof TooltipPrimitive.Content>,
|
|
React.ComponentPropsWithoutRef<typeof TooltipPrimitive.Content> & {
|
|
className?: string;
|
|
}
|
|
>(({ className, sideOffset = 6, ...props }, ref) => (
|
|
<TooltipPrimitive.Portal>
|
|
<TooltipContentPrimitive
|
|
ref={ref}
|
|
sideOffset={sideOffset}
|
|
className={cn(
|
|
"z-50 overflow-hidden rounded-lg border border-border bg-popover px-3 py-1.5 text-xs font-medium text-popover-foreground",
|
|
// Premium shadow
|
|
"shadow-lg shadow-black/10",
|
|
// Faster, snappier animations
|
|
"animate-in fade-in-0 zoom-in-95 duration-150",
|
|
"data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[state=closed]:duration-100",
|
|
// Slide from edge
|
|
"data-[side=bottom]:slide-in-from-top-1",
|
|
"data-[side=left]:slide-in-from-right-1",
|
|
"data-[side=right]:slide-in-from-left-1",
|
|
"data-[side=top]:slide-in-from-bottom-1",
|
|
className
|
|
)}
|
|
{...props}
|
|
/>
|
|
</TooltipPrimitive.Portal>
|
|
))
|
|
TooltipContent.displayName = TooltipPrimitive.Content.displayName
|
|
|
|
export { Tooltip, TooltipTrigger, TooltipContent, TooltipProvider }
|