LibreChat/client/src/components/Main/BingStyles.jsx

62 lines
2 KiB
React
Raw Normal View History

2023-03-25 09:34:00 -04:00
import React, { useState, useEffect, forwardRef } from 'react';
2023-03-24 14:46:07 -04:00
import { Tabs, TabsList, TabsTrigger } from '../ui/Tabs.tsx';
import { useDispatch, useSelector } from 'react-redux';
import { setConversation } from '~/store/convoSlice';
2023-03-24 14:46:07 -04:00
2023-03-25 09:34:00 -04:00
function BingStyles(props, ref) {
const dispatch = useDispatch();
2023-03-24 14:46:07 -04:00
const [value, setValue] = useState('fast');
const { model } = useSelector((state) => state.submit);
const { conversationId } = useSelector((state) => state.convo);
const { messages } = useSelector((state) => state.messages);
2023-03-25 09:34:00 -04:00
const isBing = model === 'bingai' || model === 'sydney';
useEffect(() => {
if (isBing && !conversationId) {
dispatch(setConversation({ toneStyle: value }));
}
}, [isBing, conversationId, model, value, dispatch]);
const show = isBing && (!conversationId || messages?.length === 0);
2023-03-24 16:31:27 -04:00
const defaultClasses = 'p-2 rounded-md font-normal bg-white/[.60] dark:bg-gray-700 text-black';
2023-03-24 14:46:07 -04:00
const defaultSelected = defaultClasses + 'font-medium data-[state=active]:text-white';
const selectedClass = (val) => val + '-tab ' + defaultSelected;
const changeHandler = value => {
setValue(value);
dispatch(setConversation({ toneStyle: value }));
2023-03-24 14:46:07 -04:00
};
return (
<Tabs
defaultValue={value}
className={`shadow-md mb-1 bing-styles ${show ? 'show' : ''}`}
onValueChange={changeHandler}
2023-03-25 09:34:00 -04:00
ref={ref}
2023-03-24 14:46:07 -04:00
>
2023-03-24 16:31:27 -04:00
<TabsList className="bg-white/[.60] dark:bg-gray-700">
2023-03-24 14:46:07 -04:00
<TabsTrigger
value="creative"
className={`${value === 'creative' ? selectedClass(value) : defaultClasses}`}
>
{'Creative'}
</TabsTrigger>
<TabsTrigger
value="fast"
className={`${value === 'fast' ? selectedClass(value) : defaultClasses}`}
>
{'Balanced'}
</TabsTrigger>
<TabsTrigger
value="precise"
className={`${value === 'precise' ? selectedClass(value) : defaultClasses}`}
>
{'Precise'}
</TabsTrigger>
</TabsList>
</Tabs>
);
}
2023-03-25 09:34:00 -04:00
export default forwardRef(BingStyles);