fosrl.pangolin/src/components/StrategySelect.tsx

71 lines
2.3 KiB
TypeScript
Raw Normal View History

"use client";
import { cn } from "@app/lib/cn";
import { RadioGroup, RadioGroupItem } from "./ui/radio-group";
2025-03-16 15:20:19 -04:00
import { useState } from "react";
interface StrategyOption {
id: string;
title: string;
description: string;
2025-03-16 15:20:19 -04:00
disabled?: boolean; // New optional property
}
interface StrategySelectProps {
options: StrategyOption[];
defaultValue?: string;
onChange?: (value: string) => void;
2025-03-16 15:20:19 -04:00
cols?: number;
}
export function StrategySelect({
options,
defaultValue,
2025-03-16 15:20:19 -04:00
onChange,
cols
}: StrategySelectProps) {
2025-03-16 15:20:19 -04:00
const [selected, setSelected] = useState(defaultValue);
return (
<RadioGroup
defaultValue={defaultValue}
2025-03-16 15:20:19 -04:00
onValueChange={(value) => {
setSelected(value);
onChange?.(value);
}}
className={`grid md:grid-cols-${cols ? cols : 1} gap-4`}
>
{options.map((option) => (
<label
key={option.id}
htmlFor={option.id}
2025-03-16 15:20:19 -04:00
data-state={
selected === option.id ? "checked" : "unchecked"
}
className={cn(
2025-03-16 15:20:19 -04:00
"relative flex rounded-lg border-2 p-4 transition-colors cursor-pointer",
option.disabled
? "border-input text-muted-foreground cursor-not-allowed opacity-50"
: selected === option.id
? "border-primary bg-primary/10 text-primary"
: "border-input hover:bg-accent"
)}
>
<RadioGroupItem
value={option.id}
id={option.id}
2025-03-16 15:20:19 -04:00
disabled={option.disabled}
className="absolute left-4 top-5 h-4 w-4 border-primary text-primary"
/>
<div className="pl-7">
<div className="font-medium">{option.title}</div>
<div className="text-sm text-muted-foreground">
{option.description}
</div>
</div>
</label>
))}
</RadioGroup>
);
}