aboutsummaryrefslogtreecommitdiffstats
path: root/web/components/ui/imageCard.tsx
diff options
context:
space:
mode:
authorMohamedBassem <me@mbassem.com>2024-02-07 16:57:47 +0000
committerMohamedBassem <me@mbassem.com>2024-02-07 16:57:47 +0000
commit293869e1743c925519d938ebeeff033c773a1ec6 (patch)
treecc61ae06d6ab36b9eea9d5313e7d82981efcaaf7 /web/components/ui/imageCard.tsx
parentdaebbf0154a290fb690ed94fca23377e0f739f53 (diff)
downloadkarakeep-293869e1743c925519d938ebeeff033c773a1ec6.tar.zst
[ui] Styling the bookmarks page
Diffstat (limited to 'web/components/ui/imageCard.tsx')
-rw-r--r--web/components/ui/imageCard.tsx56
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} />;
+}