mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-19 18:00:15 +01:00
* feat: Code Interpreter API & File Search Agent Uploads chore: add back code files wip: first pass, abstract key dialog refactor: influence checkbox on key changes refactor: update localization keys for 'execute code' to 'run code' wip: run code button refactor: add throwError parameter to loadAuthValues and getUserPluginAuthValue functions feat: first pass, API tool calling fix: handle missing toolId in callTool function and return 404 for non-existent tools feat: show code outputs fix: improve error handling in callTool function and log errors fix: handle potential null value for filepath in attachment destructuring fix: normalize language before rendering and prevent null return fix: add loading indicator in RunCode component while executing code feat: add support for conditional code execution in Markdown components feat: attachments refactor: remove bash fix: pass abort signal to graph/run refactor: debounce and rate limit tool call refactor: increase debounce delay for execute function feat: set code output attachments feat: image attachments refactor: apply message context refactor: pass `partIndex` feat: toolCall schema/model/methods feat: block indexing feat: get tool calls chore: imports chore: typing chore: condense type imports feat: get tool calls fix: block indexing chore: typing refactor: update tool calls mapping to support multiple results fix: add unique key to nav link for rendering wip: first pass, tool call results refactor: update query cache from successful tool call mutation style: improve result switcher styling chore: note on using \`.toObject()\` feat: add agent_id field to conversation schema chore: typing refactor: rename agentMap to agentsMap for consistency feat: Agent Name as chat input placeholder chore: bump agents 📦 chore: update @langchain dependencies to latest versions to match agents package 📦 chore: update @librechat/agents dependency to version 1.8.0 fix: Aborting agent stream removes sender; fix(bedrock): completion removes preset name label refactor: remove direct file parameter to use req.file, add `processAgentFileUpload` for image uploads feat: upload menu feat: prime message_file resources feat: implement conversation access validation in chat route refactor: remove file parameter from processFileUpload and use req.file instead feat: add savedMessageIds set to track saved message IDs in BaseClient, to prevent unnecessary double-write to db feat: prevent duplicate message saves by checking savedMessageIds in AgentController refactor: skip legacy RAG API handling for agents feat: add files field to convoSchema refactor: update request type annotations from Express.Request to ServerRequest in file processing functions feat: track conversation files fix: resendFiles, addPreviousAttachments handling feat: add ID validation for session_id and file_id in download route feat: entity_id for code file uploads/downloads fix: code file edge cases feat: delete related tool calls feat: add stream rate handling for LLM configuration feat: enhance system content with attached file information fix: improve error logging in resource priming function * WIP: PoC, sequential agents WIP: PoC Sequential Agents, first pass content data + bump agents package fix: package-lock WIP: PoC, o1 support, refactor bufferString feat: convertJsonSchemaToZod fix: form issues and schema defining erroneous model fix: max length issue on agent form instructions, limit conversation messages to sequential agents feat: add abort signal support to createRun function and AgentClient feat: PoC, hide prior sequential agent steps fix: update parameter naming from config to metadata in event handlers for clarity, add model to usage data refactor: use only last contentData, track model for usage data chore: bump agents package fix: content parts issue refactor: filter contentParts to include tool calls and relevant indices feat: show function calls refactor: filter context messages to exclude tool calls when no tools are available to the agent fix: ensure tool call content is not undefined in formatMessages feat: add agent_id field to conversationPreset schema feat: hide sequential agents feat: increase upload toast duration to 10 seconds * refactor: tool context handling & update Code API Key Dialog feat: toolContextMap chore: skipSpecs -> useSpecs ci: fix handleTools tests feat: API Key Dialog * feat: Agent Permissions Admin Controls feat: replace label with button for prompt permission toggle feat: update agent permissions feat: enable experimental agents and streamline capability configuration feat: implement access control for agents and enhance endpoint menu items feat: add welcome message for agent selection in localization feat: add agents permission to access control and update version to 0.7.57 * fix: update types in useAssistantListMap and useMentions hooks for better null handling * feat: mention agents * fix: agent tool resource race conditions when deleting agent tool resource files * feat: add error handling for code execution with user feedback * refactor: rename AdminControls to AdminSettings for clarity * style: add gap to button in AdminSettings for improved layout * refactor: separate agent query hooks and check access to enable fetching * fix: remove unused provider from agent initialization options, creates issue with custom endpoints * refactor: remove redundant/deprecated modelOptions from AgentClient processes * chore: update @librechat/agents to version 1.8.5 in package.json and package-lock.json * fix: minor styling issues + agent panel uniformity * fix: agent edge cases when set endpoint is no longer defined * refactor: remove unused cleanup function call from AppService * fix: update link in ApiKeyDialog to point to pricing page * fix: improve type handling and layout calculations in SidePanel component * fix: add missing localization string for agent selection in SidePanel * chore: form styling and localizations for upload filesearch/code interpreter * fix: model selection placeholder logic in AgentConfig component * style: agent capabilities * fix: add localization for provider selection and improve dropdown styling in ModelPanel * refactor: use gpt-4o-mini > gpt-3.5-turbo * fix: agents configuration for loadDefaultInterface and update related tests * feat: DALLE Agents support
136 lines
4.8 KiB
TypeScript
136 lines
4.8 KiB
TypeScript
import { Search, X } from 'lucide-react';
|
|
import React, { useState, useMemo, useCallback } from 'react';
|
|
import { useLocalize } from '~/hooks';
|
|
import { cn } from '~/utils';
|
|
|
|
// This is a generic that can be added to Menu and Select components
|
|
|
|
export default function MultiSearch({
|
|
value,
|
|
onChange,
|
|
placeholder,
|
|
className = '',
|
|
}: {
|
|
value: string | null;
|
|
onChange: (filter: string) => void;
|
|
placeholder?: string;
|
|
className?: string;
|
|
}) {
|
|
const localize = useLocalize();
|
|
const onChangeHandler: React.ChangeEventHandler<HTMLInputElement> = useCallback(
|
|
(e) => onChange(e.target.value),
|
|
[onChange],
|
|
);
|
|
|
|
return (
|
|
<div
|
|
className={cn(
|
|
'group sticky left-0 top-0 z-10 flex h-12 items-center gap-2 bg-gradient-to-b from-white from-65% to-transparent px-3 py-2 text-black transition-colors duration-300 focus:bg-gradient-to-b focus:from-white focus:to-white/50 dark:from-gray-700 dark:to-transparent dark:text-white dark:focus:from-white/10 dark:focus:to-white/20',
|
|
className,
|
|
)}
|
|
>
|
|
<Search className="h-4 w-4 text-gray-500 transition-colors duration-300 dark:group-focus-within:text-gray-300 dark:group-hover:text-gray-300" />
|
|
<input
|
|
type="text"
|
|
value={value ?? ''}
|
|
onChange={onChangeHandler}
|
|
placeholder={placeholder ?? localize('com_ui_select_search_model')}
|
|
className="flex-1 rounded-md border-none bg-transparent px-2.5 py-2 text-sm focus:outline-none focus:ring-1 focus:ring-gray-700/10 dark:focus:ring-gray-200/10"
|
|
/>
|
|
<div className="relative flex h-5 w-5 items-center justify-end text-gray-500">
|
|
<X
|
|
className={cn(
|
|
'text-gray-500 dark:text-gray-300',
|
|
value?.length ?? 0 ? 'cursor-pointer opacity-100' : 'opacity-0',
|
|
)}
|
|
onClick={() => onChange('')}
|
|
/>
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
/**
|
|
* Helper function that will take a multiSearch input
|
|
* @param node
|
|
*/
|
|
function defaultGetStringKey(node: unknown): string {
|
|
if (typeof node === 'string') {
|
|
// BUGFIX: Detect psedeo separators and make sure they don't appear in the list when filtering items
|
|
// it makes sure (for the most part) that the model name starts and ends with dashes
|
|
// The long-term fix here would be to enable seperators (model groupings) but there's no
|
|
// feature mocks for such a thing yet
|
|
if (node.startsWith('---') && node.endsWith('---')) {
|
|
return '';
|
|
}
|
|
|
|
return node.toUpperCase();
|
|
}
|
|
// This should be a noop, but it's here for redundancy
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* Hook for conditionally making a multi-element list component into a sortable component
|
|
* Returns a RenderNode for search input when search functionality is available
|
|
* @param availableOptions
|
|
* @param placeholder
|
|
* @param getTextKeyOverride
|
|
* @param className - Additional classnames to add to the search container
|
|
* @param disabled - If the search should be disabled
|
|
* @returns
|
|
*/
|
|
export function useMultiSearch<OptionsType extends unknown[]>({
|
|
availableOptions = [] as unknown as OptionsType,
|
|
placeholder,
|
|
getTextKeyOverride,
|
|
className,
|
|
disabled = false,
|
|
}: {
|
|
availableOptions?: OptionsType;
|
|
placeholder?: string;
|
|
getTextKeyOverride?: (node: OptionsType[0]) => string;
|
|
className?: string;
|
|
disabled?: boolean;
|
|
}): [OptionsType, React.ReactNode] {
|
|
const [filterValue, setFilterValue] = useState<string | null>(null);
|
|
|
|
// We conditionally show the search when there's more than 10 elements in the menu
|
|
const shouldShowSearch = availableOptions.length > 10 && !disabled;
|
|
|
|
// Define the helper function used to enable search
|
|
// If this is invalidly described, we will assume developer error - tf. avoid rendering
|
|
const getTextKeyHelper = getTextKeyOverride || defaultGetStringKey;
|
|
|
|
// Iterate said options
|
|
const filteredOptions = useMemo(() => {
|
|
const currentFilter = filterValue ?? '';
|
|
if (!shouldShowSearch || !currentFilter || !availableOptions.length) {
|
|
// Don't render if available options aren't present, there's no filter active
|
|
return availableOptions;
|
|
}
|
|
// Filter through the values, using a simple text-based search
|
|
// nothing too fancy, but we can add a better search algo later if we need
|
|
const upperFilterValue = currentFilter.toUpperCase();
|
|
|
|
return availableOptions.filter((value) =>
|
|
getTextKeyHelper(value).includes(upperFilterValue),
|
|
) as OptionsType;
|
|
}, [availableOptions, getTextKeyHelper, filterValue, shouldShowSearch]);
|
|
|
|
const onSearchChange = useCallback(
|
|
(nextFilterValue: string) => setFilterValue(nextFilterValue),
|
|
[],
|
|
);
|
|
|
|
const searchRender = shouldShowSearch ? (
|
|
<MultiSearch
|
|
value={filterValue}
|
|
className={className}
|
|
onChange={onSearchChange}
|
|
placeholder={placeholder}
|
|
/>
|
|
) : null;
|
|
|
|
return [filteredOptions, searchRender];
|
|
}
|