DB-GPT/web/pages/construct/app/extra/index.tsx
Dreammy23 471689ba20
feat(web): Unified frontend code style (#1923)
Co-authored-by: Fangyin Cheng <staneyffer@gmail.com>
Co-authored-by: 谨欣 <echo.cmy@antgroup.com>
Co-authored-by: 严志勇 <yanzhiyong@tiansuixiansheng.com>
Co-authored-by: yanzhiyong <932374019@qq.com>
2024-08-30 14:03:06 +08:00

156 lines
5.4 KiB
TypeScript

import { apiInterceptors, updateApp } from '@/client/api';
import AppDefaultIcon from '@/new-components/common/AppDefaultIcon';
import { CreateAppParams } from '@/types/app';
import { EditOutlined, LeftOutlined } from '@ant-design/icons';
import { useRequest } from 'ahooks';
import { App, Button, Space, Spin } from 'antd';
import classNames from 'classnames';
import { useRouter } from 'next/router';
import React, { useMemo, useRef, useState } from 'react';
import { useTranslation } from 'react-i18next';
import CreateAppModal from '../components/create-app-modal';
import AwelLayout from './components/AwelLayout';
import NativeApp from './components/NativeApp';
import RecommendQuestions from './components/RecommendQuestions';
import AutoPlan from './components/auto-plan';
import styles from './styles.module.css';
const ExtraAppInfo: React.FC = () => {
// 获取当前应用信息
const curApp = JSON.parse(localStorage.getItem('new_app_info') || '{}');
const { t } = useTranslation();
const { message } = App.useApp();
const router = useRouter();
const [loading, setLoading] = useState<boolean>(false);
const [open, setOpen] = useState<boolean>(false);
const appParams = useRef<CreateAppParams>({});
// 更新应用
const { run: update, loading: createLoading } = useRequest(
async (params: CreateAppParams) =>
await apiInterceptors(
updateApp({
app_code: curApp?.app_code,
app_describe: curApp?.app_describe,
team_mode: curApp?.team_mode,
app_name: curApp?.app_name,
language: curApp?.language,
...params,
}),
),
{
manual: true,
onSuccess: data => {
const [, res] = data;
if (res) {
message.success(t('update_success'));
router.replace('/construct/app');
} else {
message.error(t('update_failed'));
}
},
},
);
const submit = async () => {
await update({
...appParams.current,
});
};
const recommendQuestionsStyle = useMemo(() => {
if (curApp?.team_mode === 'awel_layout') {
return 'px-6';
}
if (curApp?.team_mode === 'auto_plan') {
return 'w-3/4 mx-auto';
}
return 'w-3/5 mx-auto';
}, [curApp?.team_mode]);
return (
<App>
<Spin spinning={loading}>
<div
className={classNames(
'flex flex-col h-screen w-screen dark:bg-gradient-dark bg-gradient-light bg-cover bg-center',
styles['extra-container'],
)}
>
<header className='flex items-center justify-between px-6 py-2 h-14 border-b border-[#edeeef]'>
<Space className='flex items-center'>
<LeftOutlined
className='text-base cursor-pointer hover:text-[#0c75fc]'
onClick={() => {
router.replace('/construct/app');
}}
/>
<div className='flex items-center justify-center w-10 h-10 border border-[#d6d8da] rounded-lg'>
<AppDefaultIcon scene={curApp?.team_context?.chat_scene || 'chat_agent'} />
</div>
<span>{curApp?.app_name}</span>
<EditOutlined className='cursor-pointer hover:text-[#0c75fc]' onClick={() => setOpen(true)} />
</Space>
<Button type='primary' onClick={submit} loading={createLoading}>
{curApp?.isEdit ? t('update') : t('save')}
</Button>
</header>
<div className='flex flex-1 flex-col py-12 max-h-full overflow-y-auto'>
{/* auto_plan模式 */}
{['single_agent', 'auto_plan'].includes(curApp?.team_mode) && (
<AutoPlan
classNames='w-3/4 mx-auto'
updateData={data => {
setLoading(data?.[0]);
appParams.current.details = data?.[1];
}}
initValue={curApp?.details}
/>
)}
{/* awel_layout模式 */}
{curApp?.team_mode === 'awel_layout' && (
<AwelLayout
initValue={curApp?.team_context}
updateData={data => {
setLoading(data?.[0]);
appParams.current.team_context = data?.[1];
}}
classNames='px-6'
/>
)}
{/* native_app模式 */}
{curApp?.team_mode === 'native_app' && (
<NativeApp
initValue={{
team_context: curApp?.team_context,
param_need: curApp?.param_need,
}}
classNames='w-3/5 mx-auto'
updateData={(data: any) => {
setLoading(data?.[0]);
appParams.current.team_context = data?.[1]?.[0];
appParams.current.param_need = data?.[1]?.[1];
}}
/>
)}
{/* single_agent模式 */}
{/* {curApp?.team_mode === '' && <></>} */}
<RecommendQuestions
updateData={data => {
appParams.current.recommend_questions = data as any;
}}
classNames={recommendQuestionsStyle}
initValue={curApp?.recommend_questions}
labelCol={curApp?.team_mode !== 'awel_layout'}
/>
</div>
</div>
</Spin>
<CreateAppModal type='edit' open={open} onCancel={() => setOpen(false)} />
</App>
);
};
export default ExtraAppInfo;