/** * * Copyright 2023-present InspectorRAGet Team * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * **/ 'use client'; import { isEmpty } from 'lodash'; import { useMemo, useState } from 'react'; import { CodeSnippet, Search } from '@carbon/react'; import { ChevronDown, ChevronUp, ToolKit } from '@carbon/icons-react'; import { ToolDefinition } from '@/src/types'; import classes from './AvailableToolsPanel.module.scss'; // --- Components --- function ToolDefinitionCard({ tool }: { tool: ToolDefinition }) { const [expanded, setExpanded] = useState(false); const hasContent = !!tool.description || (!!tool.parameters?.properties && !isEmpty(tool.parameters.properties)); return (
{tool.description}
)} {tool.parameters?.properties && !isEmpty(tool.parameters.properties) && (No tools match “{query}”
)}