|
|
|
|
@ -23,10 +23,13 @@ import React, {
|
|
|
|
|
import 'simplebar-react/dist/simplebar.min.css';
|
|
|
|
|
import { OpenAIViewCode, Roles, generateMessages } from '../../config';
|
|
|
|
|
import CompareContext from '../../config/compare-context';
|
|
|
|
|
import { ChatParamsConfig } from '../../config/params-config';
|
|
|
|
|
import { MessageItem, ModelSelectionItem } from '../../config/types';
|
|
|
|
|
import { LLM_METAKEYS, llmInitialValues } from '../../hooks/config';
|
|
|
|
|
import useChatCompletion from '../../hooks/use-chat-completion';
|
|
|
|
|
import { useInitLLmMeta } from '../../hooks/use-init-meta';
|
|
|
|
|
import '../../style/model-item.less';
|
|
|
|
|
import ParamsSettings from '../params-settings';
|
|
|
|
|
import DynamicParams from '../dynamic-params';
|
|
|
|
|
import ReferenceParams from '../reference-params';
|
|
|
|
|
import ViewCodeModal from '../view-code-modal';
|
|
|
|
|
import MessageContent from './message-content';
|
|
|
|
|
@ -39,287 +42,300 @@ interface ModelItemProps {
|
|
|
|
|
ref: any;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const ModelItem: React.FC<ModelItemProps> = forwardRef(
|
|
|
|
|
({ model, modelList, instanceId }, ref) => {
|
|
|
|
|
const {
|
|
|
|
|
globalParams,
|
|
|
|
|
setGlobalParams,
|
|
|
|
|
setLoadingStatus,
|
|
|
|
|
handleDeleteModel,
|
|
|
|
|
handleApplySystemChangeToAll,
|
|
|
|
|
modelFullList,
|
|
|
|
|
actions
|
|
|
|
|
} = useContext(CompareContext);
|
|
|
|
|
const intl = useIntl();
|
|
|
|
|
const isApplyToAllModels = useRef(false);
|
|
|
|
|
const [systemMessage, setSystemMessage] = useState<string>('');
|
|
|
|
|
const [params, setParams] = useState<Record<string, any>>({
|
|
|
|
|
const ModelItem: React.FC<ModelItemProps> = forwardRef((props, ref) => {
|
|
|
|
|
const { modelList, model, instanceId } = props;
|
|
|
|
|
const {
|
|
|
|
|
globalParams,
|
|
|
|
|
setGlobalParams,
|
|
|
|
|
setLoadingStatus,
|
|
|
|
|
handleDeleteModel,
|
|
|
|
|
handleApplySystemChangeToAll,
|
|
|
|
|
modelFullList,
|
|
|
|
|
actions
|
|
|
|
|
} = useContext(CompareContext);
|
|
|
|
|
const {
|
|
|
|
|
handleOnValuesChange,
|
|
|
|
|
handleOnModelChange,
|
|
|
|
|
setParams,
|
|
|
|
|
setInitialValues,
|
|
|
|
|
formRef,
|
|
|
|
|
paramsConfig,
|
|
|
|
|
initialValues,
|
|
|
|
|
parameters
|
|
|
|
|
} = useInitLLmMeta(props, {
|
|
|
|
|
defaultValues: {
|
|
|
|
|
...llmInitialValues,
|
|
|
|
|
model: model
|
|
|
|
|
});
|
|
|
|
|
const [show, setShow] = useState(false);
|
|
|
|
|
const scroller = useRef<any>(null);
|
|
|
|
|
},
|
|
|
|
|
defaultParamsConfig: ChatParamsConfig,
|
|
|
|
|
metaKeys: LLM_METAKEYS
|
|
|
|
|
});
|
|
|
|
|
const intl = useIntl();
|
|
|
|
|
const isApplyToAllModels = useRef(false);
|
|
|
|
|
const [systemMessage, setSystemMessage] = useState<string>('');
|
|
|
|
|
const [show, setShow] = useState(false);
|
|
|
|
|
const scroller = useRef<any>(null);
|
|
|
|
|
|
|
|
|
|
const {
|
|
|
|
|
submitMessage,
|
|
|
|
|
handleAddNewMessage,
|
|
|
|
|
handleClear,
|
|
|
|
|
setMessageList,
|
|
|
|
|
handleStopConversation,
|
|
|
|
|
tokenResult,
|
|
|
|
|
messageList,
|
|
|
|
|
loading
|
|
|
|
|
} = useChatCompletion(scroller);
|
|
|
|
|
const {
|
|
|
|
|
submitMessage,
|
|
|
|
|
handleAddNewMessage,
|
|
|
|
|
handleClear,
|
|
|
|
|
setMessageList,
|
|
|
|
|
handleStopConversation,
|
|
|
|
|
tokenResult,
|
|
|
|
|
messageList,
|
|
|
|
|
loading
|
|
|
|
|
} = useChatCompletion(scroller);
|
|
|
|
|
|
|
|
|
|
const viewCodeMessage = useMemo(() => {
|
|
|
|
|
return generateMessages([
|
|
|
|
|
{ role: Roles.System, content: systemMessage },
|
|
|
|
|
...messageList
|
|
|
|
|
]);
|
|
|
|
|
}, [messageList, systemMessage]);
|
|
|
|
|
const viewCodeMessage = useMemo(() => {
|
|
|
|
|
return generateMessages([
|
|
|
|
|
{ role: Roles.System, content: systemMessage },
|
|
|
|
|
...messageList
|
|
|
|
|
]);
|
|
|
|
|
}, [messageList, systemMessage]);
|
|
|
|
|
|
|
|
|
|
const abortFetch = () => {
|
|
|
|
|
handleStopConversation();
|
|
|
|
|
setLoadingStatus(instanceId, false);
|
|
|
|
|
};
|
|
|
|
|
const abortFetch = () => {
|
|
|
|
|
handleStopConversation();
|
|
|
|
|
setLoadingStatus(instanceId, false);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleDelete = () => {
|
|
|
|
|
handleDeleteModel(instanceId);
|
|
|
|
|
};
|
|
|
|
|
const handleDelete = () => {
|
|
|
|
|
handleDeleteModel(instanceId);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleSubmit = (currentMessage: Omit<MessageItem, 'uid'>) => {
|
|
|
|
|
const currentMsg =
|
|
|
|
|
currentMessage.content || currentMessage.imgs?.length
|
|
|
|
|
? currentMessage
|
|
|
|
|
: undefined;
|
|
|
|
|
const handleSubmit = (currentMessage: Omit<MessageItem, 'uid'>) => {
|
|
|
|
|
const currentMsg =
|
|
|
|
|
currentMessage.content || currentMessage.imgs?.length
|
|
|
|
|
? currentMessage
|
|
|
|
|
: undefined;
|
|
|
|
|
|
|
|
|
|
submitMessage({
|
|
|
|
|
system: systemMessage
|
|
|
|
|
? { role: Roles.System, content: systemMessage }
|
|
|
|
|
: undefined,
|
|
|
|
|
current: currentMsg,
|
|
|
|
|
parameters: params
|
|
|
|
|
submitMessage({
|
|
|
|
|
system: systemMessage
|
|
|
|
|
? { role: Roles.System, content: systemMessage }
|
|
|
|
|
: undefined,
|
|
|
|
|
current: currentMsg,
|
|
|
|
|
parameters: parameters
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleApplyToAllModels = (e: any) => {
|
|
|
|
|
isApplyToAllModels.current = e.target.checked;
|
|
|
|
|
if (e.target.checked) {
|
|
|
|
|
setGlobalParams({
|
|
|
|
|
..._.omit(parameters, 'model')
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleApplyToAllModels = (e: any) => {
|
|
|
|
|
isApplyToAllModels.current = e.target.checked;
|
|
|
|
|
if (e.target.checked) {
|
|
|
|
|
const OnValuesChange = useCallback(
|
|
|
|
|
(changeValues: any, allValues: Record<string, any>) => {
|
|
|
|
|
handleOnValuesChange(changeValues, {
|
|
|
|
|
...allValues,
|
|
|
|
|
model: parameters.model
|
|
|
|
|
});
|
|
|
|
|
if (isApplyToAllModels.current) {
|
|
|
|
|
setGlobalParams({
|
|
|
|
|
..._.omit(params, 'model')
|
|
|
|
|
...allValues
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
},
|
|
|
|
|
[parameters, isApplyToAllModels.current]
|
|
|
|
|
);
|
|
|
|
|
|
|
|
|
|
const handleOnValuesChange = useCallback(
|
|
|
|
|
(changeValues: any, allValues: Record<string, any>) => {
|
|
|
|
|
if (isApplyToAllModels.current) {
|
|
|
|
|
setParams({
|
|
|
|
|
...params,
|
|
|
|
|
...allValues
|
|
|
|
|
});
|
|
|
|
|
setGlobalParams({
|
|
|
|
|
...allValues
|
|
|
|
|
});
|
|
|
|
|
} else {
|
|
|
|
|
setParams({
|
|
|
|
|
...params,
|
|
|
|
|
...changeValues
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
[params, isApplyToAllModels.current]
|
|
|
|
|
);
|
|
|
|
|
const handleCloseViewCode = () => {
|
|
|
|
|
setShow(false);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleCloseViewCode = () => {
|
|
|
|
|
setShow(false);
|
|
|
|
|
};
|
|
|
|
|
const onModelChange = (value: string) => {
|
|
|
|
|
handleOnModelChange(value);
|
|
|
|
|
handleClear();
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleModelChange = (value: string) => {
|
|
|
|
|
setParams({
|
|
|
|
|
...params,
|
|
|
|
|
model: value
|
|
|
|
|
});
|
|
|
|
|
handleClear();
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const actionItems = useMemo(() => {
|
|
|
|
|
const list = [
|
|
|
|
|
{
|
|
|
|
|
label: intl.formatMessage({ id: 'common.button.clear' }),
|
|
|
|
|
key: 'clear',
|
|
|
|
|
icon: <ClearOutlined />,
|
|
|
|
|
danger: false,
|
|
|
|
|
onClick: () => {
|
|
|
|
|
setMessageList([]);
|
|
|
|
|
setSystemMessage('');
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
label: intl.formatMessage({ id: 'playground.viewcode' }),
|
|
|
|
|
key: 'viewcode',
|
|
|
|
|
icon: <IconFont type="icon-code" />,
|
|
|
|
|
onClick: () => {
|
|
|
|
|
setShow(true);
|
|
|
|
|
}
|
|
|
|
|
const actionItems = useMemo(() => {
|
|
|
|
|
const list = [
|
|
|
|
|
{
|
|
|
|
|
label: intl.formatMessage({ id: 'common.button.clear' }),
|
|
|
|
|
key: 'clear',
|
|
|
|
|
icon: <ClearOutlined />,
|
|
|
|
|
danger: false,
|
|
|
|
|
onClick: () => {
|
|
|
|
|
setMessageList([]);
|
|
|
|
|
setSystemMessage('');
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
label: intl.formatMessage({ id: 'playground.viewcode' }),
|
|
|
|
|
key: 'viewcode',
|
|
|
|
|
icon: <IconFont type="icon-code" />,
|
|
|
|
|
onClick: () => {
|
|
|
|
|
setShow(true);
|
|
|
|
|
}
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
if (modelList.length > 2) {
|
|
|
|
|
list.push({
|
|
|
|
|
label: intl.formatMessage({ id: 'common.button.delete' }),
|
|
|
|
|
key: 'delete',
|
|
|
|
|
icon: <DeleteOutlined />,
|
|
|
|
|
danger: true,
|
|
|
|
|
onClick: () => {
|
|
|
|
|
handleDelete();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
return list;
|
|
|
|
|
}, [modelList, intl]);
|
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
setParams({
|
|
|
|
|
...params,
|
|
|
|
|
...globalParams
|
|
|
|
|
if (modelList.length > 2) {
|
|
|
|
|
list.push({
|
|
|
|
|
label: intl.formatMessage({ id: 'common.button.delete' }),
|
|
|
|
|
key: 'delete',
|
|
|
|
|
icon: <DeleteOutlined />,
|
|
|
|
|
danger: true,
|
|
|
|
|
onClick: () => {
|
|
|
|
|
handleDelete();
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
}, [globalParams]);
|
|
|
|
|
}
|
|
|
|
|
return list;
|
|
|
|
|
}, [modelList, intl]);
|
|
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
setLoadingStatus(instanceId, loading);
|
|
|
|
|
return () => {
|
|
|
|
|
setLoadingStatus(instanceId, false);
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
setParams((prev: any) => {
|
|
|
|
|
return {
|
|
|
|
|
...prev,
|
|
|
|
|
...globalParams
|
|
|
|
|
};
|
|
|
|
|
}, [loading]);
|
|
|
|
|
|
|
|
|
|
useImperativeHandle(ref, () => {
|
|
|
|
|
});
|
|
|
|
|
setInitialValues((prev: any) => {
|
|
|
|
|
return {
|
|
|
|
|
submit: handleSubmit,
|
|
|
|
|
abortFetch,
|
|
|
|
|
addNewMessage: handleAddNewMessage,
|
|
|
|
|
clear: handleClear,
|
|
|
|
|
setSystemMessage,
|
|
|
|
|
loading
|
|
|
|
|
...prev,
|
|
|
|
|
...globalParams
|
|
|
|
|
};
|
|
|
|
|
});
|
|
|
|
|
}, [globalParams]);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className="model-item">
|
|
|
|
|
<div className="header">
|
|
|
|
|
<span className="title">
|
|
|
|
|
<Select
|
|
|
|
|
style={{ width: '100%' }}
|
|
|
|
|
variant="borderless"
|
|
|
|
|
options={modelFullList}
|
|
|
|
|
onChange={handleModelChange}
|
|
|
|
|
value={params.model}
|
|
|
|
|
labelRender={(data) => {
|
|
|
|
|
return (
|
|
|
|
|
<AutoTooltip
|
|
|
|
|
ghost
|
|
|
|
|
tooltipProps={{
|
|
|
|
|
placement: 'right'
|
|
|
|
|
}}
|
|
|
|
|
minWidth={60}
|
|
|
|
|
maxWidth={180}
|
|
|
|
|
>
|
|
|
|
|
{data.label}
|
|
|
|
|
</AutoTooltip>
|
|
|
|
|
);
|
|
|
|
|
}}
|
|
|
|
|
optionRender={(data) => {
|
|
|
|
|
return (
|
|
|
|
|
<AutoTooltip
|
|
|
|
|
ghost
|
|
|
|
|
tooltipProps={{
|
|
|
|
|
placement: 'right'
|
|
|
|
|
}}
|
|
|
|
|
minWidth={60}
|
|
|
|
|
maxWidth={180}
|
|
|
|
|
>
|
|
|
|
|
{data.label}
|
|
|
|
|
</AutoTooltip>
|
|
|
|
|
);
|
|
|
|
|
}}
|
|
|
|
|
></Select>
|
|
|
|
|
</span>
|
|
|
|
|
<ReferenceParams usage={tokenResult} scaleable></ReferenceParams>
|
|
|
|
|
<span className="action">
|
|
|
|
|
<Dropdown
|
|
|
|
|
menu={{
|
|
|
|
|
items: actionItems
|
|
|
|
|
}}
|
|
|
|
|
placement="bottomRight"
|
|
|
|
|
>
|
|
|
|
|
<Button
|
|
|
|
|
type="text"
|
|
|
|
|
icon={<MoreOutlined style={{ fontSize: '14px' }} />}
|
|
|
|
|
size="small"
|
|
|
|
|
></Button>
|
|
|
|
|
</Dropdown>
|
|
|
|
|
<Popover
|
|
|
|
|
placement="bottomRight"
|
|
|
|
|
content={
|
|
|
|
|
<ParamsSettings
|
|
|
|
|
showModelSelector={false}
|
|
|
|
|
setParams={setParams}
|
|
|
|
|
modelList={modelList}
|
|
|
|
|
globalParams={globalParams}
|
|
|
|
|
selectedModel={params.model}
|
|
|
|
|
onValuesChange={handleOnValuesChange}
|
|
|
|
|
/>
|
|
|
|
|
}
|
|
|
|
|
trigger={['click']}
|
|
|
|
|
arrow={false}
|
|
|
|
|
fresh={true}
|
|
|
|
|
title={
|
|
|
|
|
<div>
|
|
|
|
|
<Checkbox onChange={handleApplyToAllModels}>
|
|
|
|
|
{intl.formatMessage({
|
|
|
|
|
id: 'playground.compare.applytoall'
|
|
|
|
|
})}
|
|
|
|
|
</Checkbox>
|
|
|
|
|
</div>
|
|
|
|
|
}
|
|
|
|
|
>
|
|
|
|
|
<Button
|
|
|
|
|
type="text"
|
|
|
|
|
icon={<SettingOutlined />}
|
|
|
|
|
size="small"
|
|
|
|
|
></Button>
|
|
|
|
|
</Popover>
|
|
|
|
|
</span>
|
|
|
|
|
</div>
|
|
|
|
|
<SystemMessage
|
|
|
|
|
showApplyToAll={true}
|
|
|
|
|
systemMessage={systemMessage}
|
|
|
|
|
applyToAll={handleApplySystemChangeToAll}
|
|
|
|
|
setSystemMessage={setSystemMessage}
|
|
|
|
|
></SystemMessage>
|
|
|
|
|
<div className="content" ref={scroller}>
|
|
|
|
|
<div>
|
|
|
|
|
<MessageContent
|
|
|
|
|
messageList={messageList}
|
|
|
|
|
setMessageList={setMessageList}
|
|
|
|
|
actions={actions}
|
|
|
|
|
editable={true}
|
|
|
|
|
/>
|
|
|
|
|
<Spin spinning={loading} size="small" style={{ width: '100%' }} />
|
|
|
|
|
</div>
|
|
|
|
|
useEffect(() => {
|
|
|
|
|
setLoadingStatus(instanceId, loading);
|
|
|
|
|
return () => {
|
|
|
|
|
setLoadingStatus(instanceId, false);
|
|
|
|
|
};
|
|
|
|
|
}, [loading]);
|
|
|
|
|
|
|
|
|
|
useImperativeHandle(ref, () => {
|
|
|
|
|
return {
|
|
|
|
|
submit: handleSubmit,
|
|
|
|
|
abortFetch,
|
|
|
|
|
addNewMessage: handleAddNewMessage,
|
|
|
|
|
clear: handleClear,
|
|
|
|
|
setSystemMessage,
|
|
|
|
|
loading
|
|
|
|
|
};
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<div className="model-item">
|
|
|
|
|
<div className="header">
|
|
|
|
|
<span className="title">
|
|
|
|
|
<Select
|
|
|
|
|
style={{ width: '100%' }}
|
|
|
|
|
variant="borderless"
|
|
|
|
|
options={modelFullList}
|
|
|
|
|
onChange={onModelChange}
|
|
|
|
|
value={parameters.model}
|
|
|
|
|
labelRender={(data) => {
|
|
|
|
|
return (
|
|
|
|
|
<AutoTooltip
|
|
|
|
|
ghost
|
|
|
|
|
tooltipProps={{
|
|
|
|
|
placement: 'right'
|
|
|
|
|
}}
|
|
|
|
|
minWidth={60}
|
|
|
|
|
maxWidth={180}
|
|
|
|
|
>
|
|
|
|
|
{data.label}
|
|
|
|
|
</AutoTooltip>
|
|
|
|
|
);
|
|
|
|
|
}}
|
|
|
|
|
optionRender={(data) => {
|
|
|
|
|
return (
|
|
|
|
|
<AutoTooltip
|
|
|
|
|
ghost
|
|
|
|
|
tooltipProps={{
|
|
|
|
|
placement: 'right'
|
|
|
|
|
}}
|
|
|
|
|
minWidth={60}
|
|
|
|
|
maxWidth={180}
|
|
|
|
|
>
|
|
|
|
|
{data.label}
|
|
|
|
|
</AutoTooltip>
|
|
|
|
|
);
|
|
|
|
|
}}
|
|
|
|
|
></Select>
|
|
|
|
|
</span>
|
|
|
|
|
<ReferenceParams usage={tokenResult} scaleable></ReferenceParams>
|
|
|
|
|
<span className="action">
|
|
|
|
|
<Dropdown
|
|
|
|
|
menu={{
|
|
|
|
|
items: actionItems
|
|
|
|
|
}}
|
|
|
|
|
placement="bottomRight"
|
|
|
|
|
>
|
|
|
|
|
<Button
|
|
|
|
|
type="text"
|
|
|
|
|
icon={<MoreOutlined style={{ fontSize: '14px' }} />}
|
|
|
|
|
size="small"
|
|
|
|
|
></Button>
|
|
|
|
|
</Dropdown>
|
|
|
|
|
<Popover
|
|
|
|
|
placement="bottomRight"
|
|
|
|
|
overlayInnerStyle={{ width: 384 }}
|
|
|
|
|
content={
|
|
|
|
|
<DynamicParams
|
|
|
|
|
ref={formRef}
|
|
|
|
|
onValuesChange={OnValuesChange}
|
|
|
|
|
paramsConfig={paramsConfig}
|
|
|
|
|
initialValues={initialValues}
|
|
|
|
|
showModelSelector={false}
|
|
|
|
|
/>
|
|
|
|
|
}
|
|
|
|
|
trigger={['click']}
|
|
|
|
|
arrow={false}
|
|
|
|
|
fresh={true}
|
|
|
|
|
title={
|
|
|
|
|
<div>
|
|
|
|
|
<Checkbox onChange={handleApplyToAllModels}>
|
|
|
|
|
{intl.formatMessage({
|
|
|
|
|
id: 'playground.compare.applytoall'
|
|
|
|
|
})}
|
|
|
|
|
</Checkbox>
|
|
|
|
|
</div>
|
|
|
|
|
}
|
|
|
|
|
>
|
|
|
|
|
<Button
|
|
|
|
|
type="text"
|
|
|
|
|
icon={<SettingOutlined />}
|
|
|
|
|
size="small"
|
|
|
|
|
></Button>
|
|
|
|
|
</Popover>
|
|
|
|
|
</span>
|
|
|
|
|
</div>
|
|
|
|
|
<SystemMessage
|
|
|
|
|
showApplyToAll={true}
|
|
|
|
|
systemMessage={systemMessage}
|
|
|
|
|
applyToAll={handleApplySystemChangeToAll}
|
|
|
|
|
setSystemMessage={setSystemMessage}
|
|
|
|
|
></SystemMessage>
|
|
|
|
|
<div className="content" ref={scroller}>
|
|
|
|
|
<div>
|
|
|
|
|
<MessageContent
|
|
|
|
|
messageList={messageList}
|
|
|
|
|
setMessageList={setMessageList}
|
|
|
|
|
actions={actions}
|
|
|
|
|
editable={true}
|
|
|
|
|
/>
|
|
|
|
|
<Spin spinning={loading} size="small" style={{ width: '100%' }} />
|
|
|
|
|
</div>
|
|
|
|
|
<ViewCodeModal
|
|
|
|
|
{...OpenAIViewCode.chat}
|
|
|
|
|
open={show}
|
|
|
|
|
payload={{
|
|
|
|
|
messages: viewCodeMessage
|
|
|
|
|
}}
|
|
|
|
|
parameters={params}
|
|
|
|
|
onCancel={handleCloseViewCode}
|
|
|
|
|
title={intl.formatMessage({ id: 'playground.viewcode' })}
|
|
|
|
|
></ViewCodeModal>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
);
|
|
|
|
|
<ViewCodeModal
|
|
|
|
|
{...OpenAIViewCode.chat}
|
|
|
|
|
open={show}
|
|
|
|
|
payload={{
|
|
|
|
|
messages: viewCodeMessage
|
|
|
|
|
}}
|
|
|
|
|
parameters={parameters}
|
|
|
|
|
onCancel={handleCloseViewCode}
|
|
|
|
|
title={intl.formatMessage({ id: 'playground.viewcode' })}
|
|
|
|
|
></ViewCodeModal>
|
|
|
|
|
</div>
|
|
|
|
|
);
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
export default React.memo(ModelItem);
|
|
|
|
|
|