2023-03-24 16:21:10 -04:00
|
|
|
import React, { useState, useEffect } from 'react';
|
2023-03-24 14:46:07 -04:00
|
|
|
import { Tabs, TabsList, TabsTrigger } from '../ui/Tabs.tsx';
|
2023-03-24 16:21:10 -04:00
|
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
|
|
|
import { setConversation } from '~/store/convoSlice';
|
2023-03-24 14:46:07 -04:00
|
|
|
|
|
|
|
|
export default function BingStyles() {
|
2023-03-24 16:21:10 -04:00
|
|
|
const dispatch = useDispatch();
|
2023-03-24 14:46:07 -04:00
|
|
|
const [value, setValue] = useState('fast');
|
|
|
|
|
const { model } = useSelector((state) => state.submit);
|
2023-03-24 16:21:10 -04:00
|
|
|
const { conversationId } = useSelector((state) => state.convo);
|
|
|
|
|
const { messages } = useSelector((state) => state.messages);
|
|
|
|
|
const isBing = model === 'bingai' || model === 'sydney';
|
2023-03-24 14:46:07 -04:00
|
|
|
|
2023-03-24 16:21:10 -04:00
|
|
|
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);
|
2023-03-24 16:21:10 -04:00
|
|
|
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-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>
|
|
|
|
|
);
|
|
|
|
|
}
|