提供独立的模型供应商页面

This commit is contained in:
吴季分
2025-10-15 14:40:42 +08:00
parent 083a8a224f
commit a958a388ad
2 changed files with 70 additions and 41 deletions

View File

@@ -0,0 +1,18 @@
'use client'
import React from 'react'
import AccountSetting from '@/app/components/header/account-setting'
const ProviderPage = () => {
const hideNavMenu = () => {
// 这里可以添加隐藏导航菜单的逻辑
}
return (
<div className="h-full">
<AccountSetting onCancel={hideNavMenu} activeTab="provider" hideMenu={true} hideCloseButton={true}/>
</div>
)
}
export default ProviderPage

View File

@@ -39,6 +39,8 @@ const iconClassName = `
type IAccountSettingProps = {
onCancel: () => void
activeTab?: string
hideMenu?: boolean
hideCloseButton?: boolean
}
type GroupItem = {
@@ -52,6 +54,8 @@ type GroupItem = {
export default function AccountSetting({
onCancel,
activeTab = 'members',
hideMenu = false,
hideCloseButton = false,
}: IAccountSettingProps) {
const [activeMenu, setActiveMenu] = useState(activeTab)
const { t } = useTranslation()
@@ -149,49 +153,56 @@ export default function AccountSetting({
onClose={onCancel}
>
<div className='mx-auto flex h-[100vh] max-w-[1048px]'>
<div className='flex w-[44px] flex-col border-r border-divider-burn pl-4 pr-6 sm:w-[224px]'>
<div className='title-2xl-semi-bold mb-8 mt-6 px-3 py-2 text-text-primary'>{t('common.userProfile.settings')}</div>
<div className='w-full'>
{
menuItems.map(menuItem => (
<div key={menuItem.key} className='mb-2'>
{!isCurrentWorkspaceDatasetOperator && (
<div className='system-xs-medium-uppercase mb-0.5 py-2 pb-1 pl-3 text-text-tertiary'>{menuItem.name}</div>
)}
<div>
{
menuItem.items.map(item => (
<div
key={item.key}
className={cn(
'mb-0.5 flex h-[37px] cursor-pointer items-center rounded-lg p-1 pl-3 text-sm',
activeMenu === item.key ? 'system-sm-semibold bg-state-base-active text-components-menu-item-text-active' : 'system-sm-medium text-components-menu-item-text')}
title={item.name}
onClick={() => setActiveMenu(item.key)}
>
{activeMenu === item.key ? item.activeIcon : item.icon}
{!isMobile && <div className='truncate'>{item.name}</div>}
</div>
))
}
{!hideMenu && (
<div className='flex w-[44px] flex-col border-r border-divider-burn pl-4 pr-6 sm:w-[224px]'>
<div className='title-2xl-semi-bold mb-8 mt-6 px-3 py-2 text-text-primary'>{t('common.userProfile.settings')}</div>
<div className='w-full'>
{
menuItems.map(menuItem => (
<div key={menuItem.key} className='mb-2'>
{!isCurrentWorkspaceDatasetOperator && (
<div className='system-xs-medium-uppercase mb-0.5 py-2 pb-1 pl-3 text-text-tertiary'>{menuItem.name}</div>
)}
<div>
{
menuItem.items.map(item => (
<div
key={item.key}
className={cn(
'mb-0.5 flex h-[37px] cursor-pointer items-center rounded-lg p-1 pl-3 text-sm',
activeMenu === item.key ? 'system-sm-semibold bg-state-base-active text-components-menu-item-text-active' : 'system-sm-medium text-components-menu-item-text')}
title={item.name}
onClick={() => setActiveMenu(item.key)}
>
{activeMenu === item.key ? item.activeIcon : item.icon}
{!isMobile && <div className='truncate'>{item.name}</div>}
</div>
))
}
</div>
</div>
</div>
))
}
</div>
</div>
<div className='relative flex w-[824px]'>
<div className='absolute -right-11 top-6 z-[9999] flex flex-col items-center'>
<Button
variant='tertiary'
size='large'
className='px-2'
onClick={onCancel}
>
<RiCloseLine className='h-5 w-5' />
</Button>
<div className='system-2xs-medium-uppercase mt-1 text-text-tertiary'>ESC</div>
))
}
</div>
</div>
)}
<div className={cn(
'relative flex',
hideCloseButton ? 'w-[1048px]' : 'w-[824px]',
)}>
{!hideCloseButton && (
<div className='absolute -right-11 top-6 z-[9999] flex flex-col items-center'>
<Button
variant='tertiary'
size='large'
className='px-2'
onClick={onCancel}
>
<RiCloseLine className='h-5 w-5' />
</Button>
<div className='system-2xs-medium-uppercase mt-1 text-text-tertiary'>ESC</div>
</div>
)}
<div ref={scrollRef} className='w-full overflow-y-auto bg-components-panel-bg pb-4'>
<div className={cn('sticky top-0 z-20 mx-8 mb-[18px] flex items-center bg-components-panel-bg pb-2 pt-[27px]', scrolled && 'border-b border-divider-regular')}>
<div className='title-2xl-semi-bold shrink-0 text-text-primary'>