import { OptionTypes } from 'librechat-data-provider'; import { Label, Input, HoverCard, HoverCardTrigger } from '@librechat/client'; import type { DynamicSettingProps } from 'librechat-data-provider'; import { useLocalize, useDebouncedInput, useParameterEffects, TranslationKeys } from '~/hooks'; import { useChatContext } from '~/Providers'; import OptionHover from './OptionHover'; import { ESide } from '~/common'; import { cn } from '~/utils'; function DynamicInput({ label = '', settingKey, defaultValue, description = '', columnSpan, setOption, optionType, placeholder = '', readonly = false, showDefault = false, labelCode = false, descriptionCode = false, placeholderCode = false, conversation, }: DynamicSettingProps) { const localize = useLocalize(); const { preset } = useChatContext(); const [setInputValue, inputValue, setLocalValue] = useDebouncedInput({ optionKey: settingKey, initialValue: optionType !== OptionTypes.Custom ? conversation?.[settingKey] : defaultValue, setter: () => ({}), setOption, }); useParameterEffects({ preset, settingKey, defaultValue: typeof defaultValue === 'undefined' ? '' : defaultValue, conversation, inputValue, setInputValue: setLocalValue, }); const handleInputChange = (e: React.ChangeEvent) => { setInputValue(e, !isNaN(Number(e.target.value))); }; const placeholderText = placeholderCode ? localize(placeholder as TranslationKeys) || placeholder : placeholder; return (
{description && ( )}
); } export default DynamicInput;