use mobilepage with create user dialog

This commit is contained in:
Josh Hawkins 2025-09-22 09:06:45 -05:00
parent 0920f3b5e4
commit b148bba637

View File

@ -33,6 +33,15 @@ import {
import { Shield, User } from "lucide-react";
import { LuCheck, LuX } from "react-icons/lu";
import { useTranslation } from "react-i18next";
import { isDesktop, isMobile } from "react-device-detect";
import { cn } from "@/lib/utils";
import {
MobilePage,
MobilePageContent,
MobilePageDescription,
MobilePageHeader,
MobilePageTitle,
} from "../mobile/MobilePage";
type CreateUserOverlayProps = {
show: boolean;
@ -110,15 +119,27 @@ export default function CreateUserDialog({
onCancel();
};
const Overlay = isDesktop ? Dialog : MobilePage;
const Content = isDesktop ? DialogContent : MobilePageContent;
const Header = isDesktop ? DialogHeader : MobilePageHeader;
const Description = isDesktop ? DialogDescription : MobilePageDescription;
const Title = isDesktop ? DialogTitle : MobilePageTitle;
return (
<Dialog open={show} onOpenChange={onCancel}>
<DialogContent className="sm:max-w-[425px]">
<DialogHeader>
<DialogTitle>{t("users.dialog.createUser.title")}</DialogTitle>
<DialogDescription>
<Overlay open={show} onOpenChange={onCancel}>
<Content
className={cn(
"scrollbar-container overflow-y-auto",
isDesktop && "my-4 flex max-h-dvh flex-col sm:max-w-[425px]",
isMobile && "px-4",
)}
>
<Header className="mt-2" onClose={onCancel}>
<Title>{t("users.dialog.createUser.title")}</Title>
<Description className={cn(!isDesktop && "sr-only")}>
{t("users.dialog.createUser.desc")}
</DialogDescription>
</DialogHeader>
</Description>
</Header>
<Form {...form}>
<form
@ -286,7 +307,7 @@ export default function CreateUserDialog({
</DialogFooter>
</form>
</Form>
</DialogContent>
</Dialog>
</Content>
</Overlay>
);
}