diff options
| author | MohamedBassem <me@mbassem.com> | 2024-02-07 16:57:47 +0000 |
|---|---|---|
| committer | MohamedBassem <me@mbassem.com> | 2024-02-07 16:57:47 +0000 |
| commit | 293869e1743c925519d938ebeeff033c773a1ec6 (patch) | |
| tree | cc61ae06d6ab36b9eea9d5313e7d82981efcaaf7 /web/components/ui/imageCard.tsx | |
| parent | daebbf0154a290fb690ed94fca23377e0f739f53 (diff) | |
| download | karakeep-293869e1743c925519d938ebeeff033c773a1ec6.tar.zst | |
[ui] Styling the bookmarks page
Diffstat (limited to 'web/components/ui/imageCard.tsx')
| -rw-r--r-- | web/components/ui/imageCard.tsx | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/web/components/ui/imageCard.tsx b/web/components/ui/imageCard.tsx new file mode 100644 index 00000000..1394ae08 --- /dev/null +++ b/web/components/ui/imageCard.tsx @@ -0,0 +1,56 @@ +import * as React from "react"; + +import { cn } from "@/lib/utils"; + +export function ImageCard({ + children, + image, + className, + ...props +}: React.HTMLAttributes<HTMLDivElement> & { image?: string }) { + return ( + <div + className={cn("h-96 rounded-lg overflow-hidden shadow-md", className)} + {...props} + > + <div + className="h-3/5 bg-cover bg-center" + style={{ + backgroundImage: image ? `url(${image})` : undefined, + }} + ></div> + <div className="flex flex-col h-2/5 p-2">{children}</div> + </div> + ); +} + +export function ImageCardTitle({ + className, + ...props +}: React.HTMLAttributes<HTMLDivElement>) { + return ( + <div + className={cn("order-first flex-none font-bold text-lg", className)} + {...props} + /> + ); +} + +export function ImageCardBody({ + className, + ...props +}: React.HTMLAttributes<HTMLDivElement>) { + return ( + <div + className={cn("grow order-1 font-bold text-lg", className)} + {...props} + /> + ); +} + +export function ImageCardFooter({ + className, + ...props +}: React.HTMLAttributes<HTMLDivElement>) { + return <div className={cn("order-last", className)} {...props} />; +} |
