创建账户信息组件

This commit is contained in:
2025-06-19 09:30:04 +08:00
parent 70c89b783a
commit a1a16afb76
2 changed files with 43 additions and 2 deletions

View File

@@ -33,6 +33,7 @@ import { useRouter } from "next/navigation"
import SetPassword from "./nav-user/SetPassword" import SetPassword from "./nav-user/SetPassword"
import { useState } from "react" import { useState } from "react"
import { User } from "@/lib/types/user" import { User } from "@/lib/types/user"
import UserProfile from "./nav-user/UserProfile"
export function NavUser({ user, isUserLoading }: { user: User | undefined, isUserLoading: boolean }) { export function NavUser({ user, isUserLoading }: { user: User | undefined, isUserLoading: boolean }) {
const { isMobile } = useSidebar(); const { isMobile } = useSidebar();
@@ -50,6 +51,7 @@ export function NavUser({ user, isUserLoading }: { user: User | undefined, isUse
} }
} }
const [userProfileOpen, setUserProfileOpen] = useState(false);
const [passwordOpen, setPasswordOpen] = useState(false); const [passwordOpen, setPasswordOpen] = useState(false);
return ( return (
@@ -117,11 +119,11 @@ export function NavUser({ user, isUserLoading }: { user: User | undefined, isUse
} }
</DropdownMenuLabel> </DropdownMenuLabel>
<DropdownMenuSeparator /> <DropdownMenuSeparator />
<DropdownMenuItem> <DropdownMenuItem onClick={() => setTimeout(() => setUserProfileOpen(true), 0)}>
<UserRoundCog /> <UserRoundCog />
</DropdownMenuItem> </DropdownMenuItem>
<DropdownMenuItem onClick={() => setTimeout(() => { setPasswordOpen(true) }, 0)}> <DropdownMenuItem onClick={() => setTimeout(() => setPasswordOpen(true), 0)}>
<KeyRound /> <KeyRound />
</DropdownMenuItem> </DropdownMenuItem>
@@ -135,6 +137,7 @@ export function NavUser({ user, isUserLoading }: { user: User | undefined, isUse
</SidebarMenuItem> </SidebarMenuItem>
</SidebarMenu > </SidebarMenu >
<UserProfile open={userProfileOpen} onOpenChange={setUserProfileOpen} />
<SetPassword open={passwordOpen} onOpenChange={setPasswordOpen} /> <SetPassword open={passwordOpen} onOpenChange={setPasswordOpen} />
</> </>
) )

View File

@@ -0,0 +1,38 @@
import { DialogProps } from "@radix-ui/react-dialog";
import React, { FC } from "react";
import {
Dialog,
DialogContent,
DialogDescription,
DialogFooter,
DialogHeader,
DialogTitle,
} from "@/components/ui/dialog"
import { Button } from "../ui/button";
interface UserProfileProps {
}
export default function ({ onOpenChange, ...props }: UserProfileProps & React.ComponentProps<FC<DialogProps>>) {
return (
<Dialog onOpenChange={onOpenChange} {...props}>
<DialogContent className="sm:max-w-[425px]">
<DialogHeader>
<DialogTitle></DialogTitle>
<DialogDescription>
6-32
</DialogDescription>
</DialogHeader>
<div>
...
</div>
<DialogFooter>
<Button type="button" variant='secondary' onClick={() => onOpenChange?.(false)}></Button>
</DialogFooter>
</DialogContent>
</Dialog >
)
}