| 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; | |