114 lines
3.4 KiB
TypeScript
114 lines
3.4 KiB
TypeScript
|
|
export const basicSheet=`import { Button } from "@/components/ui/button"
|
||
|
|
import { Input } from "@/components/ui/input"
|
||
|
|
import { Label } from "@/components/ui/label"
|
||
|
|
import {
|
||
|
|
Sheet,
|
||
|
|
SheetClose,
|
||
|
|
SheetContent,
|
||
|
|
SheetDescription,
|
||
|
|
SheetFooter,
|
||
|
|
SheetHeader,
|
||
|
|
SheetTitle,
|
||
|
|
SheetTrigger,
|
||
|
|
} from "@/components/ui/sheet"
|
||
|
|
const BasicSheet = () => {
|
||
|
|
return (
|
||
|
|
<Sheet>
|
||
|
|
<SheetTrigger asChild>
|
||
|
|
<Button variant="outline">Open</Button>
|
||
|
|
</SheetTrigger>
|
||
|
|
<SheetContent>
|
||
|
|
<SheetHeader>
|
||
|
|
<SheetTitle>Edit profile</SheetTitle>
|
||
|
|
<SheetDescription>
|
||
|
|
Make changes to your profile here. Click save when you are done.
|
||
|
|
</SheetDescription>
|
||
|
|
</SheetHeader>
|
||
|
|
<div className="grid gap-4 py-4">
|
||
|
|
<div className="grid grid-cols-4 items-center gap-4">
|
||
|
|
<Label htmlFor="name" className="text-right">
|
||
|
|
Name
|
||
|
|
</Label>
|
||
|
|
<Input id="name" value="Pedro Duarte" className="col-span-3" />
|
||
|
|
</div>
|
||
|
|
<div className="grid grid-cols-4 items-center gap-4">
|
||
|
|
<Label htmlFor="username" className="text-right">
|
||
|
|
Username
|
||
|
|
</Label>
|
||
|
|
<Input id="username" value="@peduarte" className="col-span-3" />
|
||
|
|
</div>
|
||
|
|
</div>
|
||
|
|
<SheetFooter>
|
||
|
|
<SheetClose asChild>
|
||
|
|
<Button type="submit">Save changes</Button>
|
||
|
|
</SheetClose>
|
||
|
|
</SheetFooter>
|
||
|
|
</SheetContent>
|
||
|
|
</Sheet>
|
||
|
|
)
|
||
|
|
}
|
||
|
|
|
||
|
|
export default BasicSheet;`
|
||
|
|
|
||
|
|
export const sheetPosition=`"use client"
|
||
|
|
|
||
|
|
import { Button } from "@/components/ui/button"
|
||
|
|
import { Input } from "@/components/ui/input"
|
||
|
|
import { Label } from "@/components/ui/label"
|
||
|
|
import {
|
||
|
|
Sheet,
|
||
|
|
SheetClose,
|
||
|
|
SheetContent,
|
||
|
|
SheetDescription,
|
||
|
|
SheetFooter,
|
||
|
|
SheetHeader,
|
||
|
|
SheetTitle,
|
||
|
|
SheetTrigger,
|
||
|
|
} from "@/components/ui/sheet"
|
||
|
|
|
||
|
|
const SHEET_SIDES = ["top", "right", "bottom", "left"] as const
|
||
|
|
|
||
|
|
type SheetSide = (typeof SHEET_SIDES)[number]
|
||
|
|
|
||
|
|
const SheetSide = () => {
|
||
|
|
return (
|
||
|
|
<div className="flex flex-wrap gap-6">
|
||
|
|
{SHEET_SIDES.map((side) => (
|
||
|
|
<Sheet key={side}>
|
||
|
|
<SheetTrigger asChild>
|
||
|
|
<Button variant="outline" className="capitalize">Open {side}</Button>
|
||
|
|
</SheetTrigger>
|
||
|
|
<SheetContent side={side}>
|
||
|
|
<SheetHeader>
|
||
|
|
<SheetTitle>Edit profile</SheetTitle>
|
||
|
|
<SheetDescription>
|
||
|
|
Make changes to your profile here. Click save when you are done.
|
||
|
|
</SheetDescription>
|
||
|
|
</SheetHeader>
|
||
|
|
<div className="grid gap-4 py-4">
|
||
|
|
<div className="grid grid-cols-4 items-center gap-4">
|
||
|
|
<Label htmlFor="name" className="text-right">
|
||
|
|
Name
|
||
|
|
</Label>
|
||
|
|
<Input id="name" value="Pedro Duarte" className="col-span-3" />
|
||
|
|
</div>
|
||
|
|
<div className="grid grid-cols-4 items-center gap-4">
|
||
|
|
<Label htmlFor="username" className="text-right">
|
||
|
|
Username
|
||
|
|
</Label>
|
||
|
|
<Input id="username" value="@peduarte" className="col-span-3" />
|
||
|
|
</div>
|
||
|
|
</div>
|
||
|
|
<SheetFooter>
|
||
|
|
<SheetClose asChild>
|
||
|
|
<Button type="submit">Save changes</Button>
|
||
|
|
</SheetClose>
|
||
|
|
</SheetFooter>
|
||
|
|
</SheetContent>
|
||
|
|
</Sheet>
|
||
|
|
))}
|
||
|
|
</div>
|
||
|
|
)
|
||
|
|
}
|
||
|
|
|
||
|
|
export default SheetSide;`
|