mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-27 13:48:51 +01:00
* feat: Google Model Parameters * fix: dynamic input number value, previously coerced by zod schema * refactor: support openrouter reasoning tokens and XML for thinking directive to conform to ollama * fix: virtualize combobox to prevent performance drop on re-renders of long model/agent/assistant lists * refactor: simplify Fork component by removing unnecessary chat context index * fix: prevent rendering of Thinking component when children are null * refactor: update Markdown component to replace <think> tags and simplify remarkPlugins configuration * refactor: reorder remarkPlugins to improve plugin configuration in Markdown component
57 lines
1.9 KiB
TypeScript
57 lines
1.9 KiB
TypeScript
import debounce from 'lodash/debounce';
|
|
import React, { useState, useCallback } from 'react';
|
|
import type { SetterOrUpdater } from 'recoil';
|
|
import type { TSetOption } from '~/common';
|
|
import { defaultDebouncedDelay } from '~/common';
|
|
|
|
/** A custom hook that accepts a setOption function and an option key (e.g., 'title').
|
|
It manages a local state for the option value, a debounced setter function for that value,
|
|
and returns the local state value, its setter, and an onChange handler suitable for inputs. */
|
|
function useDebouncedInput<T = unknown>({
|
|
setOption,
|
|
setter,
|
|
optionKey,
|
|
initialValue,
|
|
delay = defaultDebouncedDelay,
|
|
}: {
|
|
setOption?: TSetOption;
|
|
setter?: SetterOrUpdater<T>;
|
|
optionKey?: string | number;
|
|
initialValue: T;
|
|
delay?: number;
|
|
}): [
|
|
(e: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement> | T, numeric?: boolean) => void,
|
|
T,
|
|
SetterOrUpdater<T>,
|
|
// (newValue: string) => void,
|
|
] {
|
|
const [value, setValue] = useState<T>(initialValue);
|
|
|
|
/** A debounced function to call the passed setOption with the optionKey and new value.
|
|
*
|
|
Note: We use useCallback to ensure our debounced function is stable across renders. */
|
|
const setDebouncedOption = useCallback(
|
|
debounce(setOption && optionKey ? setOption(optionKey) : setter, delay),
|
|
[],
|
|
);
|
|
|
|
/** An onChange handler that updates the local state and the debounced option */
|
|
const onChange = useCallback(
|
|
(e: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement> | T, numeric?: boolean) => {
|
|
let newValue: T =
|
|
typeof e !== 'object'
|
|
? e
|
|
: ((e as React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>).target
|
|
.value as unknown as T);
|
|
if (numeric === true) {
|
|
newValue = Number(newValue) as unknown as T;
|
|
}
|
|
setValue(newValue);
|
|
setDebouncedOption(newValue);
|
|
},
|
|
[setDebouncedOption],
|
|
);
|
|
return [onChange, value, setValue];
|
|
}
|
|
|
|
export default useDebouncedInput;
|