2
0
Files
2024-08-09 00:39:27 +02:00

174 lines
4.9 KiB
TypeScript

import * as SheetPrimitives from "@radix-ui/react-dialog";
import * as React from "react";
import classNames from "@calcom/lib/classNames";
import { Button } from "../button";
const Sheet = (props: React.ComponentPropsWithoutRef<typeof SheetPrimitives.Root>) => {
return <SheetPrimitives.Root {...props} />;
};
Sheet.displayName = "Sheet";
const SheetTrigger = React.forwardRef<
React.ElementRef<typeof SheetPrimitives.Trigger>,
React.ComponentPropsWithoutRef<typeof SheetPrimitives.Trigger>
>(({ className, ...props }, ref) => {
return <SheetPrimitives.Trigger ref={ref} className={classNames(className)} {...props} />;
});
SheetTrigger.displayName = "Sheet.Trigger";
const SheetClose = React.forwardRef<
React.ElementRef<typeof SheetPrimitives.Close>,
React.ComponentPropsWithoutRef<typeof SheetPrimitives.Close>
>(({ className, ...props }, ref) => {
return <SheetPrimitives.Close ref={ref} className={classNames(className)} {...props} />;
});
SheetClose.displayName = "Sheet.Close";
const SheetPortal = SheetPrimitives.Portal;
SheetPortal.displayName = "SheetPortal";
const SheetOverlay = React.forwardRef<
React.ElementRef<typeof SheetPrimitives.Overlay>,
React.ComponentPropsWithoutRef<typeof SheetPrimitives.Overlay>
>(({ className, ...props }, forwardedRef) => {
return (
<SheetPrimitives.Overlay
ref={forwardedRef}
className={classNames(
// base
"fixed inset-0 z-50 overflow-y-auto",
// background color
"bg-black/30",
// transition
"data-[state=closed]:animate-hide data-[state=open]:animate-dialogOverlayShow",
className
)}
{...props}
style={{
animationDuration: "400ms",
animationFillMode: "backwards",
}}
/>
);
});
SheetOverlay.displayName = "SheetOverlay";
const SheetContent = React.forwardRef<
React.ElementRef<typeof SheetPrimitives.Content>,
React.ComponentPropsWithoutRef<typeof SheetPrimitives.Content>
>(({ className, ...props }, forwardedRef) => {
return (
<SheetPortal>
<SheetOverlay>
<SheetPrimitives.Content
ref={forwardedRef}
className={classNames(
// base
"fixed inset-y-2 mx-auto flex w-[95vw] flex-1 flex-col overflow-y-auto rounded-md border p-4 shadow-lg focus:outline-none max-sm:inset-x-2 sm:inset-y-2 sm:right-2 sm:max-w-lg sm:p-6",
// border color
"border-subtle",
// background color
"bg-default",
// transition
"data-[state=closed]:animate-SheetSlideRightAndFade data-[state=open]:animate-SheetSlideLeftAndFade",
className
)}
{...props}
/>
</SheetOverlay>
</SheetPortal>
);
});
SheetContent.displayName = "SheetContent";
const SheetHeader = React.forwardRef<HTMLDivElement, React.ComponentPropsWithoutRef<"div">>(
({ children, className, ...props }, ref) => {
return (
<div
ref={ref}
className="border-subtle flex items-start justify-between gap-x-4 border-b pb-2"
{...props}>
<div className={classNames("mt-1 flex flex-col gap-y-1", className)}>{children}</div>
<SheetPrimitives.Close asChild>
<Button variant="icon" StartIcon="x" color="minimal" className="aspect-square p-1" />
</SheetPrimitives.Close>
</div>
);
}
);
SheetHeader.displayName = "Sheet.Header";
const SheetTitle = React.forwardRef<
React.ElementRef<typeof SheetPrimitives.Title>,
React.ComponentPropsWithoutRef<typeof SheetPrimitives.Title>
>(({ className, ...props }, forwardedRef) => (
<SheetPrimitives.Title
ref={forwardedRef}
className={classNames(
// base
"text-base font-semibold",
// text color
"text-default",
className
)}
{...props}
/>
));
SheetTitle.displayName = "SheetTitle";
const SheetBody = React.forwardRef<HTMLDivElement, React.ComponentPropsWithoutRef<"div">>(
({ className, ...props }, ref) => {
return <div ref={ref} className={classNames("flex-1 overflow-y-auto py-4", className)} {...props} />;
}
);
SheetBody.displayName = "Sheet.Body";
const SheetDescription = React.forwardRef<
React.ElementRef<typeof SheetPrimitives.Description>,
React.ComponentPropsWithoutRef<typeof SheetPrimitives.Description>
>(({ className, ...props }, forwardedRef) => {
return (
<SheetPrimitives.Description
ref={forwardedRef}
className={classNames("text-default", className)}
{...props}
/>
);
});
SheetDescription.displayName = "SheetDescription";
const SheetFooter = ({ className, ...props }: React.HTMLAttributes<HTMLDivElement>) => {
return (
<div
className={classNames(
"border-muted x flex flex-col-reverse border-t pt-4 sm:flex-row sm:justify-end sm:space-x-2",
className
)}
{...props}
/>
);
};
SheetFooter.displayName = "SheetFooter";
export {
Sheet,
SheetBody,
SheetClose,
SheetContent,
SheetDescription,
SheetFooter,
SheetHeader,
SheetTitle,
SheetTrigger,
};