* reorganize folder structure * move folders from merge * fix import issue * run format * update configs
67 lines
1.9 KiB
TypeScript
67 lines
1.9 KiB
TypeScript
import {
|
|
Select,
|
|
SelectContent,
|
|
SelectTrigger,
|
|
SelectValue,
|
|
} from "@radix-ui/react-select";
|
|
import {
|
|
Tooltip,
|
|
TooltipContent,
|
|
TooltipTrigger,
|
|
} from "@radix-ui/react-tooltip";
|
|
import type { ModelOption } from "@/app/api/queries/useGetModelsQuery";
|
|
import {
|
|
getFallbackModels,
|
|
type ModelProvider,
|
|
} from "@/app/settings/_helpers/model-helpers";
|
|
import { ModelSelectItems } from "@/app/settings/_helpers/model-select-item";
|
|
import { LabelWrapper } from "@/components/label-wrapper";
|
|
|
|
interface EmbeddingModelInputProps {
|
|
disabled?: boolean;
|
|
value: string;
|
|
onChange: (value: string) => void;
|
|
modelsData?: {
|
|
embedding_models: ModelOption[];
|
|
};
|
|
currentProvider?: ModelProvider;
|
|
}
|
|
|
|
export const EmbeddingModelInput = ({
|
|
disabled,
|
|
value,
|
|
onChange,
|
|
modelsData,
|
|
currentProvider = "openai",
|
|
}: EmbeddingModelInputProps) => {
|
|
const isDisabled = Boolean(disabled);
|
|
const tooltipMessage = isDisabled
|
|
? "Locked to keep embeddings consistent"
|
|
: "Choose the embedding model for ingest and retrieval";
|
|
|
|
return (
|
|
<LabelWrapper
|
|
helperText="Model used for knowledge ingest and retrieval"
|
|
id="embedding-model-select"
|
|
label="Embedding model"
|
|
>
|
|
<Select disabled={isDisabled} value={value} onValueChange={onChange}>
|
|
<Tooltip delayDuration={0}>
|
|
<TooltipTrigger asChild>
|
|
<SelectTrigger disabled={isDisabled} id="embedding-model-select">
|
|
<SelectValue placeholder="Select an embedding model" />
|
|
</SelectTrigger>
|
|
</TooltipTrigger>
|
|
<TooltipContent>{tooltipMessage}</TooltipContent>
|
|
</Tooltip>
|
|
<SelectContent>
|
|
<ModelSelectItems
|
|
models={modelsData?.embedding_models || []}
|
|
fallbackModels={getFallbackModels(currentProvider).embedding || []}
|
|
provider={currentProvider}
|
|
/>
|
|
</SelectContent>
|
|
</Select>
|
|
</LabelWrapper>
|
|
);
|
|
};
|