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';
|
2023-03-28 23:00:29 +08:00
|
|
|
import { useRecoilValue, useRecoilState } from 'recoil';
|
2023-03-31 08:36:42 -04:00
|
|
|
import { cn } from '../../utils';
|
2023-03-28 23:00:29 +08:00
|
|
|
|
|
|
|
|
import store from '~/store';
|
2023-03-24 14:46:07 -04:00
|
|
|
|
2023-03-25 09:34:00 -04:00
|
|
|
function BingStyles(props, ref) {
|
2023-03-28 23:00:29 +08:00
|
|
|
const [conversation, setConversation] = useRecoilState(store.conversation) || {};
|
2023-03-31 04:33:26 +08:00
|
|
|
const { endpoint, conversationId, jailbreak, toneStyle } = conversation;
|
2023-03-28 23:00:29 +08:00
|
|
|
const messages = useRecoilValue(store.messages);
|
2023-03-26 13:01:35 +09:00
|
|
|
|
2023-03-31 04:33:26 +08:00
|
|
|
const isBing = endpoint === 'bingAI';
|
2023-03-24 16:21:10 -04:00
|
|
|
|
2023-03-28 23:00:29 +08:00
|
|
|
const show = isBing && (!conversationId || messages?.length === 0 || props.show);
|
2023-03-31 04:33:26 +08:00
|
|
|
const defaultClasses =
|
|
|
|
|
'p-2 rounded-md min-w-[75px] font-normal bg-white/[.60] dark:bg-gray-700 text-black text-xs';
|
2023-03-31 08:36:42 -04:00
|
|
|
const defaultSelected = cn(defaultClasses, 'font-medium data-[state=active]:text-white text-xs text-white');
|
2023-03-24 14:46:07 -04:00
|
|
|
|
2023-03-28 23:00:29 +08:00
|
|
|
const selectedClass = val => val + '-tab ' + defaultSelected;
|
2023-03-24 14:46:07 -04:00
|
|
|
|
|
|
|
|
const changeHandler = value => {
|
2023-03-28 23:00:29 +08:00
|
|
|
setConversation(prevState => ({ ...prevState, toneStyle: value }));
|
2023-03-24 14:46:07 -04:00
|
|
|
};
|
2023-03-31 04:33:26 +08:00
|
|
|
|
2023-03-24 14:46:07 -04:00
|
|
|
return (
|
|
|
|
|
<Tabs
|
2023-03-31 23:15:38 +08:00
|
|
|
value={toneStyle}
|
2023-03-28 23:00:29 +08:00
|
|
|
className={`bing-styles mb-1 shadow-md ${show ? 'show' : ''}`}
|
2023-03-24 14:46:07 -04:00
|
|
|
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"
|
2023-03-31 04:33:26 +08:00
|
|
|
className={`${toneStyle === 'creative' ? selectedClass('creative') : defaultClasses}`}
|
2023-03-24 14:46:07 -04:00
|
|
|
>
|
|
|
|
|
{'Creative'}
|
|
|
|
|
</TabsTrigger>
|
|
|
|
|
<TabsTrigger
|
|
|
|
|
value="fast"
|
2023-03-31 04:33:26 +08:00
|
|
|
className={`${toneStyle === 'fast' ? selectedClass('fast') : defaultClasses}`}
|
2023-03-26 12:50:12 +09:00
|
|
|
>
|
|
|
|
|
{'Fast'}
|
|
|
|
|
</TabsTrigger>
|
|
|
|
|
<TabsTrigger
|
|
|
|
|
value="balanced"
|
2023-03-31 04:33:26 +08:00
|
|
|
className={`${toneStyle === 'balanced' ? selectedClass('balanced') : defaultClasses}`}
|
2023-03-24 14:46:07 -04:00
|
|
|
>
|
|
|
|
|
{'Balanced'}
|
|
|
|
|
</TabsTrigger>
|
|
|
|
|
<TabsTrigger
|
|
|
|
|
value="precise"
|
2023-03-31 04:33:26 +08:00
|
|
|
className={`${toneStyle === 'precise' ? selectedClass('precise') : defaultClasses}`}
|
2023-03-24 14:46:07 -04:00
|
|
|
>
|
|
|
|
|
{'Precise'}
|
|
|
|
|
</TabsTrigger>
|
|
|
|
|
</TabsList>
|
|
|
|
|
</Tabs>
|
|
|
|
|
);
|
|
|
|
|
}
|
2023-03-25 09:34:00 -04:00
|
|
|
|
|
|
|
|
export default forwardRef(BingStyles);
|