mirror of
https://github.com/qier222/YesPlayMusic.git
synced 2025-02-28 10:27:42 +08:00
90 lines
2.8 KiB
TypeScript
90 lines
2.8 KiB
TypeScript
import Tabs from '@/web/components/Tabs'
|
|
import { fetchDailyRecommendPlaylists, fetchRecommendedPlaylists } from '@/web/api/playlist'
|
|
import { PlaylistApiNames } from '@/shared/api/Playlists'
|
|
import { useState } from 'react'
|
|
import { useQuery } from '@tanstack/react-query'
|
|
import CoverRowVirtual from '@/web/components/CoverRowVirtual'
|
|
import PageTransition from '@/web/components/PageTransition'
|
|
import { playerWidth, topbarHeight } from '@/web/utils/const'
|
|
import { cx, css } from '@emotion/css'
|
|
import CoverRow from '@/web/components/CoverRow'
|
|
import topbarBackground from '@/web/assets/images/topbar-background.png'
|
|
|
|
const reactQueryOptions = {
|
|
refetchOnWindowFocus: false,
|
|
refetchInterval: 1000 * 60 * 60, // 1 hour
|
|
refetchOnMount: false,
|
|
}
|
|
|
|
const Recommend = () => {
|
|
const { data: dailyRecommendPlaylists, isLoading: isLoadingDaily } = useQuery(
|
|
[PlaylistApiNames.FetchDailyRecommendPlaylists],
|
|
() => fetchDailyRecommendPlaylists(),
|
|
reactQueryOptions
|
|
)
|
|
const { data: recommendedPlaylists, isLoading: isLoading } = useQuery(
|
|
[PlaylistApiNames.FetchRecommendedPlaylists, { limit: 200 }],
|
|
() => fetchRecommendedPlaylists({ limit: 200 }),
|
|
reactQueryOptions
|
|
)
|
|
const playlists =
|
|
isLoadingDaily || isLoading
|
|
? []
|
|
: [...(dailyRecommendPlaylists?.recommend || []), ...(recommendedPlaylists?.result || [])]
|
|
|
|
return <CoverRowVirtual playlists={playlists} />
|
|
|
|
// return <CoverRow playlists={playlists} />
|
|
}
|
|
|
|
const All = () => {
|
|
return <div></div>
|
|
}
|
|
|
|
const categories = [
|
|
{ id: 'recommend', name: 'Recommend', component: <Recommend /> },
|
|
{ id: 'all', name: 'All', component: <All /> },
|
|
{ id: 'featured', name: 'Featured', component: <Recommend /> },
|
|
{ id: 'official', name: 'Official', component: <Recommend /> },
|
|
{ id: 'charts', name: 'Charts', component: <Recommend /> },
|
|
]
|
|
const categoriesKeys = categories.map(c => c.id)
|
|
type Key = typeof categoriesKeys[number]
|
|
|
|
const Browse = () => {
|
|
const [active, setActive] = useState<Key>('recommend')
|
|
|
|
return (
|
|
<PageTransition>
|
|
<div className='relative'>
|
|
{/* Topbar background */}
|
|
<div
|
|
className={cx(
|
|
'pointer-events-none fixed top-0 left-10 z-10 hidden lg:block',
|
|
css`
|
|
height: 230px;
|
|
`
|
|
)}
|
|
style={{
|
|
right: `${playerWidth + 32}px`,
|
|
backgroundImage: `url(${topbarBackground})`,
|
|
}}
|
|
></div>
|
|
|
|
<Tabs
|
|
tabs={categories}
|
|
value={active}
|
|
onChange={category => setActive(category)}
|
|
className='absolute top-0 z-10 mt-2.5 px-2.5 lg:mt-0 lg:px-0'
|
|
/>
|
|
|
|
<div className='absolute inset-0 mx-2.5 mt-5 lg:mx-0 lg:mt-0'>
|
|
{categories.find(c => c.id === active)?.component}
|
|
</div>
|
|
</div>
|
|
</PageTransition>
|
|
)
|
|
}
|
|
|
|
export default Browse
|