106 lines
8.6 KiB
TypeScript
Raw Normal View History

2022-05-12 02:45:43 +08:00
import Avatar from '@/web/components/Avatar'
2022-05-29 17:53:27 +08:00
import Icon from '@/web/components/Icon'
import useUser from '@/web/api/hooks/useUser'
import Appearance from './Appearance'
2022-05-01 19:53:25 +08:00
import UnblockNeteaseMusic from './UnblockNeteaseMusic'
2022-05-29 17:53:27 +08:00
import { cx } from '@emotion/css'
2022-05-12 02:45:43 +08:00
import { useState } from 'react'
import toast from 'react-hot-toast'
const UserCard = () => {
const { data: user } = useUser()
return (
<div className='flex items-center justify-between rounded-2xl bg-gray-50 p-6 dark:bg-gray-800'>
<div className='flex items-center'>
<Avatar size='h-16 w-16' />
<div className='ml-4'>
<div className=' text-xl font-semibold dark:text-white'>
{user?.profile?.nickname ?? '未登录'}
</div>
{(user?.profile?.signature || user?.profile?.vipType) && (
<div className='mt-1 flex items-center text-sm text-gray-500 dark:text-gray-400'>
{user?.profile?.vipType ? (
<img
className='mr-1 h-4'
src='
/>
) : null}
{user?.profile?.signature}
</div>
)}
</div>
</div>
<div>
<button
onClick={() => toast('开发中')}
className='btn-pressed-animation btn-hover-animation flex items-center px-4 py-3 text-lg font-medium text-gray-600 after:rounded-xl after:bg-black/[.06] dark:text-gray-300 dark:after:bg-white/5'
>
{/* TODO: 画登入登出图标 */}
2022-05-29 17:53:27 +08:00
<Icon name='x' className='mr-1 h-6 w-6' />
{user?.profile ? '登出' : '登录'}
</button>
</div>
</div>
)
}
2022-05-01 19:53:25 +08:00
const Sidebar = ({
activeCategory,
setActiveCategory,
}: {
activeCategory: string
setActiveCategory: (category: string) => void
}) => {
const categories = [
'外观',
'播放',
'歌词',
'其他',
'UnblockNeteaseMusic',
'试验性功能',
]
return (
<div>
{categories.map(category => (
<div
key={category}
2022-05-01 19:53:25 +08:00
onClick={() => setActiveCategory(category)}
2022-05-12 02:45:43 +08:00
className={cx(
2022-04-29 19:16:34 +08:00
'btn-hover-animation my-px flex cursor-default items-center justify-between rounded-lg px-3 py-2 font-medium transition-colors duration-200 after:scale-[0.97] after:bg-black/[.06] dark:text-white dark:after:bg-white/10',
2022-05-01 19:53:25 +08:00
activeCategory === category
2022-04-29 19:16:34 +08:00
? 'text-black after:scale-100 after:opacity-100'
: 'text-gray-600'
)}
>
{category}
</div>
))}
</div>
)
}
const Settings = () => {
2022-05-01 19:53:25 +08:00
const [activeCategory, setActiveCategory] = useState('外观')
return (
<div className='mt-6'>
<UserCard />
<div className='mt-8 grid grid-cols-[12rem_auto] gap-10'>
2022-05-01 19:53:25 +08:00
<Sidebar
activeCategory={activeCategory}
setActiveCategory={setActiveCategory}
/>
<div className=''>
2022-05-01 19:53:25 +08:00
{activeCategory === '外观' && <Appearance />}
{activeCategory === 'UnblockNeteaseMusic' && <UnblockNeteaseMusic />}
</div>
</div>
</div>
)
}
export default Settings