import * as React from "react";
import * as TabsPrimitive from "@radix-ui/react-tabs";
import { cva, type VariantProps } from "class-variance-authority";

import { cn } from "../../lib/utils";

/* -------------------------------------------------------------------------------------------------
 * Tabs Root
 * -----------------------------------------------------------------------------------------------*/
interface MoonUITabsProProps extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.Root> {
  /** Mobil görünümde dikey düzen için */
  vertical?: boolean;
}

const MoonUITabsPro = React.forwardRef<
  React.ElementRef<typeof TabsPrimitive.Root>,
  MoonUITabsProProps
>(({ vertical = false, ...props }, ref) => (
  <TabsPrimitive.Root
    ref={ref}
    orientation={vertical ? "vertical" : "horizontal"}
    {...props}
  />
));

MoonUITabsPro.displayName = TabsPrimitive.Root.displayName;

/* -------------------------------------------------------------------------------------------------
 * TabsList
 * -----------------------------------------------------------------------------------------------*/
const tabsListVariants = cva(
  "flex items-center justify-start transition-all duration-200",
  {
    variants: {
      variant: {
        default: "bg-muted rounded-md p-1 text-muted-foreground dark:bg-gray-800/80 dark:text-gray-400",
        pills: "bg-transparent gap-2 p-0 dark:text-gray-400", 
        underline: "bg-transparent border-b border-border dark:border-gray-700 gap-4 dark:text-gray-400",
        cards: "bg-transparent gap-2 p-0 dark:text-gray-400",
        minimal: "bg-transparent gap-1 p-0 dark:text-gray-400",
      },
      orientation: {
        horizontal: "flex-row",
        vertical: "flex-col items-start gap-1"
      },
      fullWidth: {
        true: "w-full"
      }
    },
    defaultVariants: {
      variant: "default",
      orientation: "horizontal",
      fullWidth: false
    }
  }
);

interface MoonUITabsListProProps 
  extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.List>,
    VariantProps<typeof tabsListVariants> {
  /** Dikey düzende göster */
  orientation?: "horizontal" | "vertical";
}

const MoonUITabsListPro = React.forwardRef<
  React.ElementRef<typeof TabsPrimitive.List>,
  MoonUITabsListProProps
>(({ className, variant, orientation, fullWidth, ...props }, ref) => (
  <TabsPrimitive.List
    ref={ref}
    className={cn(tabsListVariants({ variant, orientation, fullWidth, className }))}
    {...props}
  />
));

MoonUITabsListPro.displayName = TabsPrimitive.List.displayName;

/* -------------------------------------------------------------------------------------------------
 * TabsTrigger
 * -----------------------------------------------------------------------------------------------*/
const tabsTriggerVariants = cva(
  "inline-flex items-center justify-center whitespace-nowrap font-medium ring-offset-background transition-all duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50",
  {
    variants: {
      variant: {
        default: "rounded-md data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-sm dark:data-[state=active]:bg-gray-900 dark:data-[state=active]:text-gray-100 dark:data-[state=active]:shadow-gray-950/10",
        underline: "rounded-none border-b-2 border-transparent pb-2 data-[state=active]:border-primary data-[state=active]:bg-transparent data-[state=active]:text-foreground dark:data-[state=active]:border-primary/80 dark:data-[state=active]:text-gray-100",
        pills: "rounded-full bg-muted hover:bg-muted/80 data-[state=active]:bg-primary data-[state=active]:text-primary-foreground dark:bg-gray-800 dark:hover:bg-gray-700 dark:data-[state=active]:bg-primary/90 dark:data-[state=active]:text-white",
        cards: "rounded-md bg-muted/50 hover:bg-muted data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow-md dark:bg-gray-800/50 dark:hover:bg-gray-700/50 dark:data-[state=active]:bg-gray-900 dark:data-[state=active]:text-gray-100 dark:data-[state=active]:shadow-gray-950/20",
        minimal: "rounded-sm bg-transparent hover:bg-muted/30 data-[state=active]:bg-transparent data-[state=active]:text-foreground data-[state=active]:underline data-[state=active]:underline-offset-4 dark:hover:bg-gray-800/30 dark:data-[state=active]:text-gray-200",
      },
      size: {
        sm: "h-7 px-2 text-xs",
        md: "h-9 px-3 py-1.5 text-sm",
        lg: "h-10 px-4 py-2 text-base",
      },
      orientation: {
        horizontal: "",
        vertical: "justify-start w-full text-left"
      },
      fullWidth: {
        true: "w-full"
      }
    },
    defaultVariants: {
      variant: "default",
      size: "md",
      orientation: "horizontal",
      fullWidth: false
    }
  }
);

interface MoonUITabsTriggerProProps
  extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.Trigger>,
    VariantProps<typeof tabsTriggerVariants> {
  /** İkon konumu */
  iconPosition?: "left" | "right" | "none";
  /** İkon */
  icon?: React.ReactNode;
  /** Badge içeriği */
  badge?: React.ReactNode;
  /** Aktif olmayan durumda yarı saydam */
  fadeTabs?: boolean;
  /** Dikey düzende göster */
  orientation?: "horizontal" | "vertical";
}

const MoonUITabsTriggerPro = React.forwardRef<
  React.ElementRef<typeof TabsPrimitive.Trigger>,
  MoonUITabsTriggerProProps
>(({ 
  className, 
  variant, 
  size, 
  icon, 
  iconPosition = "left", 
  badge,
  fadeTabs = false,
  orientation,
  fullWidth,
  children, 
  ...props 
}, ref) => (
  <TabsPrimitive.Trigger
    ref={ref}
    className={cn(
      tabsTriggerVariants({ variant, size, orientation, fullWidth }),
      fadeTabs && "data-[state=inactive]:opacity-60",
      className
    )}
    {...props}
  >
    {icon && iconPosition === "left" && (
      <span className="mr-2">{icon}</span>
    )}
    {children}
    {icon && iconPosition === "right" && (
      <span className="ml-2">{icon}</span>
    )}
    {badge && (
      <span className="ml-2">{badge}</span>
    )}
  </TabsPrimitive.Trigger>
));

MoonUITabsTriggerPro.displayName = TabsPrimitive.Trigger.displayName;

/* -------------------------------------------------------------------------------------------------
 * TabsContent
 * -----------------------------------------------------------------------------------------------*/
interface MoonUITabsContentProProps 
  extends React.ComponentPropsWithoutRef<typeof TabsPrimitive.Content> {
  /** İçerik animasyonu */
  animated?: boolean;
}

const MoonUITabsContentPro = React.forwardRef<
  React.ElementRef<typeof TabsPrimitive.Content>,
  MoonUITabsContentProProps
>(({ className, animated = false, ...props }, ref) => (
  <TabsPrimitive.Content
    ref={ref}
    className={cn(
      "focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2",
      animated && "data-[state=active]:animate-fadeIn data-[state=inactive]:animate-fadeOut",
      className
    )}
    {...props}
  />
));

MoonUITabsContentPro.displayName = TabsPrimitive.Content.displayName;

export { MoonUITabsPro, MoonUITabsListPro, MoonUITabsTriggerPro, MoonUITabsContentPro  };

// Backward compatibility exports
export { MoonUITabsPro as Tabs, MoonUITabsListPro as TabsList, MoonUITabsTriggerPro as TabsTrigger, MoonUITabsContentPro as TabsContent };