| import { useRecoilValue, useSetRecoilState } from 'recoil'; |
| import type { TPreset, TPlugin } from 'librechat-data-provider'; |
| import type { TSetOptionsPayload, TSetExample, TSetOption, TSetOptions } from '~/common'; |
| import { useChatContext } from '~/Providers/ChatContext'; |
| import { cleanupPreset } from '~/utils'; |
| import store from '~/store'; |
|
|
| type TUsePresetOptions = (preset?: TPreset | boolean | null) => TSetOptionsPayload | boolean; |
|
|
| const usePresetIndexOptions: TUsePresetOptions = (_preset) => { |
| const setShowPluginStoreDialog = useSetRecoilState(store.showPluginStoreDialog); |
| const availableTools = useRecoilValue(store.availableTools); |
| const { preset, setPreset } = useChatContext(); |
|
|
| if (!_preset) { |
| return false; |
| } |
| const getConversation: () => TPreset | null = () => preset; |
|
|
| const setOptions: TSetOptions = (options) => { |
| const update = { ...options }; |
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| ...update, |
| }, |
| }), |
| ); |
| }; |
|
|
| const setOption: TSetOption = (param) => (newValue) => { |
| const update = {}; |
| update[param] = newValue; |
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| ...update, |
| }, |
| }), |
| ); |
| }; |
|
|
| const setExample: TSetExample = (i, type, newValue = null) => { |
| const update = {}; |
| const current = preset?.examples?.slice() || []; |
| const currentExample = { ...current[i] } || {}; |
| currentExample[type] = { content: newValue }; |
| current[i] = currentExample; |
| update['examples'] = current; |
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| ...update, |
| }, |
| }), |
| ); |
| }; |
|
|
| const addExample: () => void = () => { |
| const update = {}; |
| const current = preset?.examples?.slice() || []; |
| current.push({ input: { content: '' }, output: { content: '' } }); |
| update['examples'] = current; |
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| ...update, |
| }, |
| }), |
| ); |
| }; |
|
|
| const removeExample: () => void = () => { |
| const update = {}; |
| const current = preset?.examples?.slice() || []; |
| if (current.length <= 1) { |
| update['examples'] = [{ input: { content: '' }, output: { content: '' } }]; |
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| ...update, |
| }, |
| }), |
| ); |
| return; |
| } |
| current.pop(); |
| update['examples'] = current; |
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| ...update, |
| }, |
| }), |
| ); |
| }; |
|
|
| const setAgentOption: TSetOption = (param) => (newValue) => { |
| const editablePreset = JSON.parse(JSON.stringify(_preset)); |
| const { agentOptions } = editablePreset; |
| agentOptions[param] = newValue; |
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| agentOptions, |
| }, |
| }), |
| ); |
| }; |
|
|
| function checkPluginSelection(value: string) { |
| if (!preset?.tools) { |
| return false; |
| } |
| return preset.tools.find((el) => { |
| if (typeof el === 'string') { |
| return el === value; |
| } |
| return el.pluginKey === value; |
| }) |
| ? true |
| : false; |
| } |
|
|
| const setTools: (newValue: string, remove?: boolean) => void = (newValue, remove) => { |
| if (newValue === 'pluginStore') { |
| setShowPluginStoreDialog(true); |
| return; |
| } |
|
|
| const update = {}; |
| const current = |
| preset?.tools |
| ?.map((tool: string | TPlugin) => { |
| if (typeof tool === 'string') { |
| return availableTools[tool]; |
| } |
| return tool; |
| }) |
| .filter((el) => !!el) || []; |
| const isSelected = checkPluginSelection(newValue); |
| const tool = availableTools[newValue]; |
| if (isSelected || remove) { |
| update['tools'] = current.filter((el) => el.pluginKey !== newValue); |
| } else { |
| update['tools'] = [...current, tool]; |
| } |
|
|
| setPreset((prevState) => |
| cleanupPreset({ |
| preset: { |
| ...prevState, |
| ...update, |
| }, |
| }), |
| ); |
| }; |
|
|
| return { |
| setOption, |
| setExample, |
| addExample, |
| setOptions, |
| removeExample, |
| getConversation, |
| checkPluginSelection, |
| setAgentOption, |
| setTools, |
| }; |
| }; |
|
|
| export default usePresetIndexOptions; |
|
|