import React, { useState, useEffect } from 'react'; import { useRecoilValue, useRecoilState } from 'recoil'; import { cn } from '~/utils'; import { Button } from '../../ui/Button.tsx'; import { Settings2 } from 'lucide-react'; import { Tabs, TabsList, TabsTrigger } from '../../ui/Tabs.tsx'; import SelectDropdown from '../../ui/SelectDropdown'; import Settings from '../../Endpoints/BingAI/Settings.jsx'; import EndpointOptionsPopover from '../../Endpoints/EndpointOptionsPopover'; import SaveAsPresetDialog from '../../Endpoints/SaveAsPresetDialog'; import store from '~/store'; function BingAIOptions() { const [conversation, setConversation] = useRecoilState(store.conversation) || {}; const [advancedMode, setAdvancedMode] = useState(false); const [saveAsDialogShow, setSaveAsDialogShow] = useState(false); const { endpoint, conversationId } = conversation; const { toneStyle, context, systemMessage, jailbreak } = conversation; // useEffect(() => { // if (endpoint !== 'bingAI') return; // const mustInAdvancedMode = context !== null || systemMessage !== null; // if (mustInAdvancedMode && !advancedMode) setAdvancedMode(true); // }, [conversation, advancedMode]); if (endpoint !== 'bingAI') return null; if (conversationId !== 'new') return null; const triggerAdvancedMode = () => setAdvancedMode(prev => !prev); const switchToSimpleMode = () => { // setConversation(prevState => ({ // ...prevState, // context: null, // systemMessage: null // })); setAdvancedMode(false); }; const saveAsPreset = () => { setSaveAsDialogShow(true); }; const setOption = param => newValue => { let update = {}; update[param] = newValue; setConversation(prevState => ({ ...prevState, ...update })); }; const cardStyle = 'transition-colors shadow-md rounded-md min-w-[75px] font-normal bg-white border-black/10 hover:border-black/10 focus:border-black/10 dark:border-black/10 dark:hover:border-black/10 dark:focus:border-black/10 border dark:bg-gray-700 text-black dark:text-white'; const defaultClasses = 'p-2 rounded-md min-w-[75px] font-normal bg-white/[.60] dark:bg-gray-700 text-black text-xs'; const defaultSelected = cn(defaultClasses, 'font-medium data-[state=active]:text-white text-xs text-white'); const selectedClass = val => val + '-tab ' + defaultSelected; return ( <>
setOption('jailbreak')(value === 'Sydney')} availableValues={['BingAI', 'Sydney']} showAbove={true} showLabel={false} className={cn( cardStyle, 'min-w-36 z-50 flex h-[40px] w-36 flex-none items-center justify-center px-4 ring-0 hover:cursor-pointer hover:bg-slate-50 focus:ring-0 focus:ring-offset-0 data-[state=open]:bg-slate-50 dark:bg-gray-700 dark:hover:bg-gray-600 dark:data-[state=open]:bg-gray-600' )} /> setOption('toneStyle')(value.toLowerCase())} > {'Creative'} {'Fast'} {'Balanced'} {'Precise'}
} visible={advancedMode} saveAsPreset={saveAsPreset} switchToSimpleMode={switchToSimpleMode} /> ); } export default BingAIOptions;