mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-20 10:20:15 +01:00
* create common types in client * remove unnecessary rules from eslint config * cleanup types * put back eslintrc rules
142 lines
4 KiB
TypeScript
142 lines
4 KiB
TypeScript
import { TConversation, TPreset, TPlugin, tConversationSchema } from 'librechat-data-provider';
|
|
import type { TSetExample, TSetOption, TSetOptionsPayload } from '~/common';
|
|
import { useRecoilState, useRecoilValue, useSetRecoilState } from 'recoil';
|
|
import usePresetOptions from './usePresetOptions';
|
|
import store from '~/store';
|
|
|
|
type TUseSetOptions = (preset?: TPreset | boolean | null) => TSetOptionsPayload;
|
|
|
|
const useSetOptions: TUseSetOptions = (preset = false) => {
|
|
const setShowPluginStoreDialog = useSetRecoilState(store.showPluginStoreDialog);
|
|
const [conversation, setConversation] = useRecoilState(store.conversation);
|
|
const availableTools = useRecoilValue(store.availableTools);
|
|
|
|
const result = usePresetOptions(preset);
|
|
|
|
if (result && typeof result !== 'boolean') {
|
|
return result;
|
|
}
|
|
|
|
const setOption: TSetOption = (param) => (newValue) => {
|
|
const update = {};
|
|
update[param] = newValue;
|
|
setConversation((prevState) =>
|
|
tConversationSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}),
|
|
);
|
|
};
|
|
|
|
const setExample: TSetExample = (i, type, newValue = null) => {
|
|
const update = {};
|
|
const current = conversation?.examples?.slice() || [];
|
|
const currentExample = { ...current[i] } || {};
|
|
currentExample[type] = { content: newValue };
|
|
current[i] = currentExample;
|
|
update['examples'] = current;
|
|
setConversation((prevState) =>
|
|
tConversationSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}),
|
|
);
|
|
};
|
|
|
|
const addExample: () => void = () => {
|
|
const update = {};
|
|
const current = conversation?.examples?.slice() || [];
|
|
current.push({ input: { content: '' }, output: { content: '' } });
|
|
update['examples'] = current;
|
|
setConversation((prevState) =>
|
|
tConversationSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}),
|
|
);
|
|
};
|
|
|
|
const removeExample: () => void = () => {
|
|
const update = {};
|
|
const current = conversation?.examples?.slice() || [];
|
|
if (current.length <= 1) {
|
|
update['examples'] = [{ input: { content: '' }, output: { content: '' } }];
|
|
setConversation((prevState) =>
|
|
tConversationSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}),
|
|
);
|
|
return;
|
|
}
|
|
current.pop();
|
|
update['examples'] = current;
|
|
setConversation((prevState) =>
|
|
tConversationSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}),
|
|
);
|
|
};
|
|
|
|
const getConversation: () => TConversation | null = () => conversation;
|
|
|
|
function checkPluginSelection(value: string) {
|
|
if (!conversation?.tools) {
|
|
return false;
|
|
}
|
|
return conversation.tools.find((el) => el.pluginKey === value) ? true : false;
|
|
}
|
|
|
|
const setAgentOption: TSetOption = (param) => (newValue) => {
|
|
const editableConvo = JSON.stringify(conversation);
|
|
const convo = JSON.parse(editableConvo);
|
|
const { agentOptions } = convo;
|
|
agentOptions[param] = newValue;
|
|
setConversation((prevState) =>
|
|
tConversationSchema.parse({
|
|
...prevState,
|
|
agentOptions,
|
|
}),
|
|
);
|
|
};
|
|
|
|
const setTools: (newValue: string) => void = (newValue) => {
|
|
if (newValue === 'pluginStore') {
|
|
setShowPluginStoreDialog(true);
|
|
return;
|
|
}
|
|
|
|
const update = {};
|
|
const current = conversation?.tools || [];
|
|
const isSelected = checkPluginSelection(newValue);
|
|
const tool =
|
|
availableTools[availableTools.findIndex((el: TPlugin) => el.pluginKey === newValue)];
|
|
if (isSelected) {
|
|
update['tools'] = current.filter((el) => el.pluginKey !== newValue);
|
|
} else {
|
|
update['tools'] = [...current, tool];
|
|
}
|
|
|
|
localStorage.setItem('lastSelectedTools', JSON.stringify(update['tools']));
|
|
setConversation((prevState) =>
|
|
tConversationSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}),
|
|
);
|
|
};
|
|
|
|
return {
|
|
setOption,
|
|
setExample,
|
|
addExample,
|
|
removeExample,
|
|
setAgentOption,
|
|
getConversation,
|
|
checkPluginSelection,
|
|
setTools,
|
|
};
|
|
};
|
|
|
|
export default useSetOptions;
|