完成admin-user-get
This commit is contained in:
@@ -21,6 +21,13 @@ export class AdminUserController {
|
|||||||
return this.adminUserService.getUser(listDto.page, listDto.pageSize);
|
return this.adminUserService.getUser(listDto.page, listDto.pageSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Get(':userId')
|
||||||
|
async get(
|
||||||
|
@Param('userId', new ParseUUIDPipe({ version: '4' })) userId: string,
|
||||||
|
) {
|
||||||
|
return this.userService.findOne({ userId });
|
||||||
|
}
|
||||||
|
|
||||||
@Post()
|
@Post()
|
||||||
async create(
|
async create(
|
||||||
@Body() createDto: CreateDto
|
@Body() createDto: CreateDto
|
||||||
|
|||||||
@@ -14,6 +14,9 @@ import {
|
|||||||
} from "@/components/ui/drawer"
|
} from "@/components/ui/drawer"
|
||||||
import { Input } from "@/components/ui/input"
|
import { Input } from "@/components/ui/input"
|
||||||
import { Label } from "@/components/ui/label"
|
import { Label } from "@/components/ui/label"
|
||||||
|
import { useUser } from "@/hooks/admin/user/use-user";
|
||||||
|
import { User } from "@/lib/types/user";
|
||||||
|
import { Skeleton } from "@/components/ui/skeleton";
|
||||||
|
|
||||||
export function UserInfoEditor({
|
export function UserInfoEditor({
|
||||||
onClose,
|
onClose,
|
||||||
@@ -22,6 +25,8 @@ export function UserInfoEditor({
|
|||||||
onClose: () => void,
|
onClose: () => void,
|
||||||
userId: string
|
userId: string
|
||||||
}) {
|
}) {
|
||||||
|
const { user, isLoading, error } = userId ? useUser(userId) : {};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Drawer open={!!userId} onClose={onClose} >
|
<Drawer open={!!userId} onClose={onClose} >
|
||||||
<DrawerContent>
|
<DrawerContent>
|
||||||
@@ -29,7 +34,17 @@ export function UserInfoEditor({
|
|||||||
<DrawerTitle>编辑用户信息</DrawerTitle>
|
<DrawerTitle>编辑用户信息</DrawerTitle>
|
||||||
<DrawerDescription>确保你在保存之前检查所有更改</DrawerDescription>
|
<DrawerDescription>确保你在保存之前检查所有更改</DrawerDescription>
|
||||||
</DrawerHeader>
|
</DrawerHeader>
|
||||||
<ProfileForm className="px-4" />
|
|
||||||
|
{user && <ProfileForm className="px-4" user={user} onSubmit={(e) => {
|
||||||
|
e.preventDefault();
|
||||||
|
}} />}
|
||||||
|
|
||||||
|
{isLoading &&
|
||||||
|
[...Array(5)].map((_, i) => (
|
||||||
|
<Skeleton className="h-20 mx-4 my-1" key={i} />
|
||||||
|
))
|
||||||
|
}
|
||||||
|
|
||||||
<DrawerFooter className="pt-2">
|
<DrawerFooter className="pt-2">
|
||||||
<DrawerClose asChild>
|
<DrawerClose asChild>
|
||||||
<Button variant="outline">关闭</Button>
|
<Button variant="outline">关闭</Button>
|
||||||
@@ -40,28 +55,28 @@ export function UserInfoEditor({
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
function ProfileForm({ className }: React.ComponentProps<"form">) {
|
function ProfileForm({ className, user, ...props }: React.ComponentProps<"form"> & { user: User }) {
|
||||||
return (
|
return (
|
||||||
<form className={cn("grid items-start gap-4", className)}>
|
<form className={cn("grid items-start gap-4", className)} {...props}>
|
||||||
<div className="grid gap-2">
|
<div className="grid gap-2">
|
||||||
<Label htmlFor="email">UserId</Label>
|
<Label htmlFor="email">UserId</Label>
|
||||||
<Input id="email" defaultValue="adijasiodjoi2q" disabled />
|
<Input id="email" defaultValue={user.userId} disabled />
|
||||||
</div>
|
</div>
|
||||||
<div className="grid gap-2">
|
<div className="grid gap-2">
|
||||||
<Label htmlFor="username">账户</Label>
|
<Label htmlFor="username">账户</Label>
|
||||||
<Input id="username" defaultValue="username" />
|
<Input id="username" defaultValue={user.username} />
|
||||||
</div>
|
</div>
|
||||||
<div className="grid gap-2">
|
<div className="grid gap-2">
|
||||||
<Label htmlFor="nickname">昵称</Label>
|
<Label htmlFor="nickname">昵称</Label>
|
||||||
<Input id="nickname" defaultValue="nickname" />
|
<Input id="nickname" defaultValue={user.nickname} />
|
||||||
</div>
|
</div>
|
||||||
<div className="grid gap-2">
|
<div className="grid gap-2">
|
||||||
<Label htmlFor="email">电子邮箱</Label>
|
<Label htmlFor="email">电子邮箱</Label>
|
||||||
<Input id="email" defaultValue="email" />
|
<Input id="email" defaultValue={user.email} />
|
||||||
</div>
|
</div>
|
||||||
<div className="grid gap-2">
|
<div className="grid gap-2">
|
||||||
<Label htmlFor="phone">手机号</Label>
|
<Label htmlFor="phone">手机号</Label>
|
||||||
<Input id="phone" defaultValue="phone" />
|
<Input id="phone" defaultValue={user.phone} />
|
||||||
</div>
|
</div>
|
||||||
<Button type="submit">保存</Button>
|
<Button type="submit">保存</Button>
|
||||||
</form>
|
</form>
|
||||||
|
|||||||
@@ -9,15 +9,6 @@ export function useUserList(params?: UserListParams) {
|
|||||||
const { data, error, isLoading, mutate } = useSWR<UserListResponse>(
|
const { data, error, isLoading, mutate } = useSWR<UserListResponse>(
|
||||||
['/api/admin/user', params],
|
['/api/admin/user', params],
|
||||||
() => list(params),
|
() => list(params),
|
||||||
{
|
|
||||||
onError: (err) => {
|
|
||||||
if (err instanceof ApiError) {
|
|
||||||
toast.error(err.message)
|
|
||||||
} else {
|
|
||||||
toast.error('请求失败')
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
)
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
|||||||
23
tone-page-web/hooks/admin/user/use-user.ts
Normal file
23
tone-page-web/hooks/admin/user/use-user.ts
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
import { AdminApi } from "@/lib/api";
|
||||||
|
import { User } from "@/lib/types/user";
|
||||||
|
import useSWR from "swr";
|
||||||
|
|
||||||
|
export function useUser(userId: string) {
|
||||||
|
const { data, error, isLoading, mutate } = useSWR<User>(
|
||||||
|
['/api/admin/user', userId],
|
||||||
|
() => AdminApi.user.get(userId),
|
||||||
|
{
|
||||||
|
revalidateOnFocus: false,
|
||||||
|
revalidateOnReconnect: false,
|
||||||
|
revalidateIfStale: false,
|
||||||
|
dedupingInterval: 0,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
return {
|
||||||
|
user: data,
|
||||||
|
isLoading,
|
||||||
|
error,
|
||||||
|
mutate,
|
||||||
|
}
|
||||||
|
}
|
||||||
6
tone-page-web/lib/api/admin/user/get.ts
Normal file
6
tone-page-web/lib/api/admin/user/get.ts
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
import { User } from "@/lib/types/user";
|
||||||
|
import fetcher from "../../fetcher";
|
||||||
|
|
||||||
|
export function get(userId: string) {
|
||||||
|
return fetcher<User>(`/api/admin/user/${userId}`);
|
||||||
|
}
|
||||||
@@ -1 +1,2 @@
|
|||||||
export * from './list';
|
export * from './list';
|
||||||
|
export * from './get';
|
||||||
Reference in New Issue
Block a user