import { PluginRunBoxProps } from '@/components/core/chat/ChatContainer/PluginRunBox/type'; import { useSystem } from '@fastgpt/web/hooks/useSystem'; import React, { useEffect } from 'react'; import PluginRunBox from '@/components/core/chat/ChatContainer/PluginRunBox'; import { Box, Grid, Stack } from '@chakra-ui/react'; import { useTranslation } from 'next-i18next'; import { PluginRunBoxTabEnum } from '@/components/core/chat/ChatContainer/PluginRunBox/constants'; import LightRowTabs from '@fastgpt/web/components/common/Tabs/LightRowTabs'; import { ChatItemContext } from '@/web/core/chat/context/chatItemContext'; import { useContextSelector } from 'use-context-selector'; const CustomPluginRunBox = (props: PluginRunBoxProps) => { const { isPc } = useSystem(); const { t } = useTranslation(); const tab = useContextSelector(ChatItemContext, (v) => v.pluginRunTab); const setTab = useContextSelector(ChatItemContext, (v) => v.setPluginRunTab); useEffect(() => { if (isPc && tab === PluginRunBoxTabEnum.input) { setTab(PluginRunBoxTabEnum.output); } }, [isPc, setTab, tab]); return isPc ? ( {t('common:common.Input')} list={[ { label: t('common:common.Output'), value: PluginRunBoxTabEnum.output }, { label: t('common:common.all_result'), value: PluginRunBoxTabEnum.detail } ]} value={tab} onChange={setTab} inlineStyles={{ px: 0.5, pt: 0 }} gap={5} py={0} fontSize={'sm'} /> ) : ( list={[ { label: t('common:common.Input'), value: PluginRunBoxTabEnum.input }, { label: t('common:common.Output'), value: PluginRunBoxTabEnum.output }, { label: t('common:common.all_result'), value: PluginRunBoxTabEnum.detail } ]} value={tab} onChange={setTab} inlineStyles={{ px: 0.5, pt: 0 }} gap={5} py={0} fontSize={'sm'} /> ); }; export default React.memo(CustomPluginRunBox);