mirror of
https://github.com/danny-avila/LibreChat.git
synced 2026-01-23 18:56:12 +01:00
* chore(ChatGPTClient.js): add support for OpenRouter API chore(OpenAIClient.js): add support for OpenRouter API * chore: comment out token debugging * chore: add back streamResult assignment * chore: remove double condition/assignment from merging * refactor(routes/endpoints): -> controller/services logic * feat: add openrouter model fetching * chore: remove unused endpointsConfig in cleanupPreset function * refactor: separate models concern from endpointsConfig * refactor(data-provider): add TModels type and make TEndpointsConfig adaptible to new endpoint keys * refactor: complete models endpoint service in data-provider * refactor: onMutate for refreshToken and login, invalidate models query * feat: complete models endpoint logic for frontend * chore: remove requireJwtAuth from /api/endpoints and /api/models as not implemented yet * fix: endpoint will not be overwritten and instead use active value * feat: openrouter support for plugins * chore(EndpointOptionsDialog): remove unused recoil value * refactor(schemas/parseConvo): add handling of secondaryModels to use first of defined secondary models, which includes last selected one as first, or default to the convo's secondary model value * refactor: remove hooks from store and move to hooks refactor(switchToConversation): make switchToConversation use latest recoil state, which is necessary to get the most up-to-date models list, replace wrapper function refactor(getDefaultConversation): factor out logic into 3 pieces to reduce complexity. * fix: backend tests * feat: optimistic update by calling newConvo when models are fetched * feat: openrouter support for titling convos * feat: cache models fetch * chore: add missing dep to AuthContext useEffect * chore: fix useTimeout types * chore: delete old getDefaultConvo file * chore: remove newConvo logic from Root, remove console log from api models caching * chore: ensure bun is used for building in b:client script * fix: default endpoint will not default to null on a completely fresh login (no localStorage/cookies) * chore: add openrouter docs to free_ai_apis.md and .env.example * chore: remove openrouter console logs * feat: add debugging env variable for Plugins
64 lines
2.2 KiB
TypeScript
64 lines
2.2 KiB
TypeScript
import React, { useEffect, useState } from 'react';
|
|
import { useCreatePresetMutation } from 'librechat-data-provider';
|
|
import type { TEditPresetProps } from '~/common';
|
|
import { Dialog, Input, Label } from '~/components/ui/';
|
|
import DialogTemplate from '~/components/ui/DialogTemplate';
|
|
import { cn, defaultTextPropsLabel, removeFocusOutlines, cleanupPreset } from '~/utils/';
|
|
import { useLocalize } from '~/hooks';
|
|
|
|
const SaveAsPresetDialog = ({ open, onOpenChange, preset }: TEditPresetProps) => {
|
|
const [title, setTitle] = useState<string>(preset?.title || 'My Preset');
|
|
const createPresetMutation = useCreatePresetMutation();
|
|
const localize = useLocalize();
|
|
|
|
const submitPreset = () => {
|
|
const _preset = cleanupPreset({
|
|
preset: {
|
|
...preset,
|
|
title,
|
|
},
|
|
});
|
|
createPresetMutation.mutate(_preset);
|
|
};
|
|
|
|
useEffect(() => {
|
|
setTitle(preset?.title || localize('com_endpoint_my_preset'));
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
}, [open]);
|
|
|
|
return (
|
|
<Dialog open={open} onOpenChange={onOpenChange}>
|
|
<DialogTemplate
|
|
title={localize('com_endpoint_save_as_preset')}
|
|
className="w-full sm:w-1/4"
|
|
main={
|
|
<div className="flex w-full flex-col items-center gap-2">
|
|
<div className="grid w-full items-center gap-2">
|
|
<Label htmlFor="chatGptLabel" className="text-left text-sm font-medium">
|
|
{localize('com_endpoint_preset_name')}
|
|
</Label>
|
|
<Input
|
|
id="chatGptLabel"
|
|
value={title || ''}
|
|
onChange={(e) => setTitle(e.target.value || '')}
|
|
placeholder="Set a custom name for this preset"
|
|
className={cn(
|
|
defaultTextPropsLabel,
|
|
'flex h-10 max-h-10 w-full resize-none px-3 py-2',
|
|
removeFocusOutlines,
|
|
)}
|
|
/>
|
|
</div>
|
|
</div>
|
|
}
|
|
selection={{
|
|
selectHandler: submitPreset,
|
|
selectClasses: 'bg-green-600 hover:bg-green-700 dark:hover:bg-green-800 text-white',
|
|
selectText: localize('com_ui_save'),
|
|
}}
|
|
/>
|
|
</Dialog>
|
|
);
|
|
};
|
|
|
|
export default SaveAsPresetDialog;
|