import { ChevronDown, Sliders, Star, Zap } from 'lucide-react'; import { cn } from '@/lib/utils'; import { Popover, PopoverButton, PopoverPanel, Transition, } from '@headlessui/react'; import { Fragment } from 'react'; import { useTranslations } from 'next-intl'; import { useChat } from '@/lib/hooks/useChat'; const OptimizationModes = [ { key: 'speed', icon: , }, { key: 'balanced', icon: , }, { key: 'quality', icon: ( ), }, ]; const Optimization = () => { const { optimizationMode, setOptimizationMode } = useChat(); const t = useTranslations('components.optimization'); return (
{ OptimizationModes.find((mode) => mode.key === optimizationMode) ?.icon }

{t(`modes.${optimizationMode}.title`)}

{OptimizationModes.map((mode, i) => ( setOptimizationMode(mode.key)} key={i} disabled={mode.key === 'quality'} className={cn( 'p-2 rounded-lg flex flex-col items-start justify-start text-start space-y-1 duration-200 cursor-pointer transition', optimizationMode === mode.key ? 'bg-light-secondary dark:bg-dark-secondary' : 'hover:bg-light-secondary dark:hover:bg-dark-secondary', mode.key === 'quality' && 'opacity-50 cursor-not-allowed', )} >
{mode.icon}

{t(`modes.${mode.key}.title`)}

{t(`modes.${mode.key}.description`)}

))}
); }; export default Optimization;