mirror of
https://github.com/AutoMaker-Org/automaker.git
synced 2026-02-01 08:13:37 +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.
125 lines
3.5 KiB
TypeScript
125 lines
3.5 KiB
TypeScript
"use client"
|
|
|
|
import * as React from "react"
|
|
import * as TabsPrimitive from "@radix-ui/react-tabs"
|
|
|
|
import { cn } from "@/lib/utils"
|
|
|
|
// Type-safe wrappers for Radix UI primitives (React 19 compatibility)
|
|
const TabsRootPrimitive = TabsPrimitive.Root as React.ForwardRefExoticComponent<
|
|
React.ComponentPropsWithoutRef<typeof TabsPrimitive.Root> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
} & React.RefAttributes<HTMLDivElement>
|
|
>;
|
|
|
|
const TabsListPrimitive = TabsPrimitive.List as React.ForwardRefExoticComponent<
|
|
React.ComponentPropsWithoutRef<typeof TabsPrimitive.List> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
} & React.RefAttributes<HTMLDivElement>
|
|
>;
|
|
|
|
const TabsTriggerPrimitive = TabsPrimitive.Trigger as React.ForwardRefExoticComponent<
|
|
React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
} & React.RefAttributes<HTMLButtonElement>
|
|
>;
|
|
|
|
const TabsContentPrimitive = TabsPrimitive.Content as React.ForwardRefExoticComponent<
|
|
React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
} & React.RefAttributes<HTMLDivElement>
|
|
>;
|
|
|
|
function Tabs({
|
|
className,
|
|
children,
|
|
...props
|
|
}: React.ComponentProps<typeof TabsPrimitive.Root> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
}) {
|
|
return (
|
|
<TabsRootPrimitive
|
|
data-slot="tabs"
|
|
className={cn("flex flex-col gap-2", className)}
|
|
{...props}
|
|
>
|
|
{children}
|
|
</TabsRootPrimitive>
|
|
)
|
|
}
|
|
|
|
function TabsList({
|
|
className,
|
|
children,
|
|
...props
|
|
}: React.ComponentProps<typeof TabsPrimitive.List> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
}) {
|
|
return (
|
|
<TabsListPrimitive
|
|
data-slot="tabs-list"
|
|
className={cn(
|
|
"bg-muted text-muted-foreground inline-flex h-9 w-fit items-center justify-center rounded-lg p-[3px] border border-border",
|
|
className
|
|
)}
|
|
{...props}
|
|
>
|
|
{children}
|
|
</TabsListPrimitive>
|
|
)
|
|
}
|
|
|
|
function TabsTrigger({
|
|
className,
|
|
children,
|
|
...props
|
|
}: React.ComponentProps<typeof TabsPrimitive.Trigger> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
}) {
|
|
return (
|
|
<TabsTriggerPrimitive
|
|
data-slot="tabs-trigger"
|
|
className={cn(
|
|
"inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap transition-all duration-200 cursor-pointer",
|
|
"text-foreground/70 hover:text-foreground hover:bg-accent",
|
|
"data-[state=active]:bg-primary data-[state=active]:text-primary-foreground data-[state=active]:shadow-md data-[state=active]:border-primary/50",
|
|
"focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring focus-visible:ring-[3px] focus-visible:outline-1",
|
|
"disabled:pointer-events-none disabled:opacity-50 disabled:cursor-not-allowed",
|
|
"[&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4",
|
|
className
|
|
)}
|
|
{...props}
|
|
>
|
|
{children}
|
|
</TabsTriggerPrimitive>
|
|
)
|
|
}
|
|
|
|
function TabsContent({
|
|
className,
|
|
children,
|
|
...props
|
|
}: React.ComponentProps<typeof TabsPrimitive.Content> & {
|
|
children?: React.ReactNode;
|
|
className?: string;
|
|
}) {
|
|
return (
|
|
<TabsContentPrimitive
|
|
data-slot="tabs-content"
|
|
className={cn("flex-1 outline-none", className)}
|
|
{...props}
|
|
>
|
|
{children}
|
|
</TabsContentPrimitive>
|
|
)
|
|
}
|
|
|
|
export { Tabs, TabsList, TabsTrigger, TabsContent }
|