Files
web/src/app/admin/resources/page.tsx

53 lines
1.0 KiB
TypeScript
Raw Normal View History

2025-04-09 17:17:39 +08:00
'use client'
import {ReactNode, useEffect, useState} from 'react'
import {PageRecord} from '@/lib/api'
import {ResourcePss} from '@/lib/models'
import {useStatus} from '@/lib/states'
import {listResourcePss} from '@/actions/resource'
2025-04-09 17:17:39 +08:00
export type ResourcesPageProps = {}
export default function ResourcesPage(props: ResourcesPageProps) {
// region 数据
const [status, setStatus] = useStatus()
const [data, setData] = useState<PageRecord<ResourcePss>>({
page: 1,
size: 10,
total: 0,
list: [],
})
const refresh = async (page: number, size: number) => {
setStatus('load')
try {
const res = await listResourcePss({page, size})
setStatus('done')
if (res.success) {
setData(res.data)
}
else {
throw new Error('Failed to load resource pss')
}
}
catch (e) {
setStatus('fail')
}
}
useEffect(() => {
refresh(1, 10).then()
}, [])
// endregion
2025-04-09 17:17:39 +08:00
// render
return (
2025-04-09 17:17:39 +08:00
<main className={`flex-auto bg-white rounded-tl-xl`}>
</main>
)
}