dify/web/app/components/explore/try-app/index.tsx
2025-10-23 16:53:10 +08:00

61 lines
1.9 KiB
TypeScript

'use client'
import type { FC } from 'react'
import React, { useState } from 'react'
import Modal from '@/app/components/base/modal/index'
import Tab, { TypeEnum } from './tab'
import Button from '../../base/button'
import { RiCloseLine } from '@remixicon/react'
import AppInfo from './app-info'
import App from './app'
import Preview from './preview'
import { useGetTryAppInfo } from '@/service/use-try-app'
import Loading from '@/app/components/base/loading'
type Props = {
appId: string
onClose: () => void
}
const TryApp: FC<Props> = ({
appId,
onClose,
}) => {
const [type, setType] = useState<TypeEnum>(TypeEnum.TRY)
const { data: appDetail, isLoading } = useGetTryAppInfo(appId)
return (
<Modal
isShow
onClose={onClose}
className='h-[calc(100vh-32px)] max-w-[calc(100vw-32px)] p-2'
>
{isLoading ? (<div className='flex h-full items-center justify-center'>
<Loading type='area' />
</div>) : (
<div className='flex h-full flex-col'>
<div className='flex shrink-0 justify-between pl-4'>
<Tab
value={type}
onChange={setType}
/>
<Button
size='large'
variant='tertiary'
className='flex size-7 items-center justify-center rounded-[10px] p-0 text-components-button-tertiary-text'
onClick={onClose}
>
<RiCloseLine className='size-5' onClick={onClose} />
</Button>
</div>
{/* Main content */}
<div className='mt-2 flex h-0 grow justify-between space-x-2'>
{type === TypeEnum.TRY ? <App appId={appId} appDetail={appDetail!} /> : <Preview appId={appId} appDetail={appDetail!} />}
<AppInfo className='w-[360px] shrink-0' appDetail={appDetail!} />
</div>
</div>
)}
</Modal>
)
}
export default React.memo(TryApp)