// client/src/components/SidePanel/Parameters/DynamicTextarea.tsx import { OptionTypes } from 'librechat-data-provider'; import type { DynamicSettingProps } from 'librechat-data-provider'; import { Label, TextareaAutosize, HoverCard, HoverCardTrigger } from '~/components/ui'; import { useLocalize, useDebouncedInput, useParameterEffects } from '~/hooks'; import { cn, defaultTextProps } from '~/utils'; import { useChatContext } from '~/Providers'; import OptionHover from './OptionHover'; import { ESide } from '~/common'; function DynamicTextarea({ label, settingKey, defaultValue, description, columnSpan, setOption, optionType, placeholder, readonly = false, showDefault = true, labelCode, descriptionCode, placeholderCode, }: DynamicSettingProps) { const localize = useLocalize(); const { conversation = { conversationId: null }, preset } = useChatContext(); const [setInputValue, inputValue] = useDebouncedInput({ optionKey: optionType !== OptionTypes.Custom ? settingKey : undefined, initialValue: optionType !== OptionTypes.Custom ? (conversation?.[settingKey] as string) : (defaultValue as string), setter: () => ({}), setOption, }); useParameterEffects({ preset, settingKey, defaultValue: typeof defaultValue === 'undefined' ? '' : defaultValue, conversation, inputValue, setInputValue, }); return (
{description && ( )}
); } export default DynamicTextarea;